first commit

This commit is contained in:
takalalika
2020-12-11 02:37:18 +08:00
parent d8a0c1c889
commit 8792a08031
15 changed files with 3377 additions and 1 deletions
+32 -1
View File
@@ -1 +1,32 @@
# auto-server
# auto-server
docker-compose 使用 nginx-proxy 在一台小鸡下部署多个项目 支持ssl。
此项目的目的是为了自用时候方便,顺便做记录,*不保证所有参数都调优且高可用*。
## 目录
use_ssl:支持docker-compose一键搭建并使用ssl
normal:一些人不喜欢https或者如果套用cf再用 Let’s Encrypt 生成证书会出问题。这两种情况用这个目录下的
这两个目录任选一个使用
## 核心
use_ssl/nginx-proxy 或者 normal/nginx-proxy 目录下的docker-compose,好奇可以自行google image后面的内容
如果只是使用可以直接运行
## 使用步骤
1.下载docker 和 docker-compose 并启动
具体参照[docker手册](https:://yeasy.gitbook.io/docker_practice/install "Markdown")。
2.创建一个 Docker network
docker network create nginx-proxy
3.到对应目录启动 nginx-proxy
4.修改并启动需要启动的服务的docker-compose中的参数
如bitwarden下的
- VIRTUAL_HOST=example.test.com
- LETSENCRYPT_HOST=example.test.com
- DEFAULT_EMAIL=xxx@gmail.com
将对应的域名和邮箱修改,不使用ssl的情况下 只需要修改VIRTUAL_HOST
## 参照
http://einverne.github.io/post/2017/02/docker-nginx-host-multiple-websites.html
看见这篇文章开始折腾的
https://blog.csdn.net/jiangyu1013/article/details/80881097
nginx-proxy 是使用的docker的数据卷没有自定义挂载,需要操作数据卷的朋友可以参照这篇
+14
View File
@@ -0,0 +1,14 @@
version: "3.6"
services:
bitwarden:
environment:
- VIRTUAL_HOST=example.test.com
image: bitwardenrs/server:1.16.3
restart: unless-stopped
volumes:
- ./bw_data:/data
networks:
default:
external:
name: nginx-proxy
File diff suppressed because it is too large Load Diff
File diff suppressed because one or more lines are too long
+19
View File
@@ -0,0 +1,19 @@
server {
listen 80;
index index.php index.html;
server_name localhost;
error_log /var/log/nginx/error.log;
access_log /var/log/nginx/access.log;
root /home/wwwroot/;
location ~ .php {
# try_files $uri =404;
fastcgi_split_path_info ^(.+.php)(/.+)$;
fastcgi_pass php:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_param PATH_INFO $fastcgi_path_info;
include fastcgi_params;
}
}
+19
View File
@@ -0,0 +1,19 @@
version: '3'
services:
web:
environment:
- VIRTUAL_HOST=example.test.com
image: nginx:latest
volumes:
- ./app:/home/wwwroot/
- ./config/nginx/site.conf:/etc/nginx/conf.d/default.conf
php:
image: php:7.0-fpm
volumes:
- ./app:/home/wwwroot/
networks:
default:
external:
name: nginx-proxy
+13
View File
@@ -0,0 +1,13 @@
version: "3.6"
services:
nginx-proxy:
image: jwilder/nginx-proxy
ports:
- "80:80"
volumes:
- /var/run/docker.sock:/tmp/docker.sock:ro
networks:
default:
external:
name: nginx-proxy
+33
View File
@@ -0,0 +1,33 @@
version: "3"
services:
db_node_domain:
image: mysql:8.0
command:
- --default_authentication_plugin=mysql_native_password
- --character-set-server=utf8mb4
- --collation-server=utf8mb4_unicode_ci
volumes:
- ./db_data:/var/lib/mysql
restart: always
environment:
MYSQL_ROOT_PASSWORD: somewordpress_wp
MYSQL_DATABASE: wordpress
MYSQL_USER: wordpress
MYSQL_PASSWORD: wordpress
wordpress:
depends_on:
- db_node_domain
image: wordpress:latest
restart: always
environment:
VIRTUAL_HOST: example.test.com
WORDPRESS_DB_HOST: db_node_domain:3306
WORDPRESS_DB_USER: wordpress
WORDPRESS_DB_PASSWORD: wordpress
networks:
default:
external:
name: nginx-proxy
+16
View File
@@ -0,0 +1,16 @@
version: "3.6"
services:
bitwarden:
environment:
- VIRTUAL_HOST=example.test.com
- LETSENCRYPT_HOST=example.test.com
- DEFAULT_EMAIL=xxx@gmail.com
image: bitwardenrs/server:1.16.3
restart: unless-stopped
volumes:
- ./bw_data:/data
networks:
default:
external:
name: nginx-proxy
File diff suppressed because it is too large Load Diff
File diff suppressed because one or more lines are too long
@@ -0,0 +1,19 @@
server {
listen 80;
index index.php index.html;
server_name localhost;
error_log /var/log/nginx/error.log;
access_log /var/log/nginx/access.log;
root /home/wwwroot/;
location ~ .php {
# try_files $uri =404;
fastcgi_split_path_info ^(.+.php)(/.+)$;
fastcgi_pass php:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_param PATH_INFO $fastcgi_path_info;
include fastcgi_params;
}
}
+21
View File
@@ -0,0 +1,21 @@
version: '3'
services:
web:
environment:
- VIRTUAL_HOST=example.test.com
- LETSENCRYPT_HOST=example.test.com
- DEFAULT_EMAIL=xxx@gmail.com
image: nginx:latest
volumes:
- ./app:/home/wwwroot/
- ./config/nginx/site.conf:/etc/nginx/conf.d/default.conf
php:
image: php:7.0-fpm
volumes:
- ./app:/home/wwwroot/
networks:
default:
external:
name: nginx-proxy
+34
View File
@@ -0,0 +1,34 @@
version: "3.6"
services:
nginx-proxy:
image: jwilder/nginx-proxy
ports:
- "443:443"
- "80:80"
environment:
- DHPARAM_GENERATION=false
labels:
- com.github.jrcs.letsencrypt_nginx_proxy_companion.nginx_proxy
volumes:
- /var/run/docker.sock:/tmp/docker.sock:ro
- nginx-certs:/etc/nginx/certs
- nginx-vhost:/etc/nginx/vhost.d
- nginx-share:/usr/share/nginx/html
nginx-letsencrypt:
image: jrcs/letsencrypt-nginx-proxy-companion
depends_on:
- nginx-proxy
volumes:
- /var/run/docker.sock:/var/run/docker.sock:ro
- nginx-certs:/etc/nginx/certs
- nginx-vhost:/etc/nginx/vhost.d
- nginx-share:/usr/share/nginx/html
volumes:
nginx-certs:
nginx-vhost:
nginx-share:
networks:
default:
external:
name: nginx-proxy
+35
View File
@@ -0,0 +1,35 @@
version: "3"
services:
db_node_domain:
image: mysql:8.0
command:
- --default_authentication_plugin=mysql_native_password
- --character-set-server=utf8mb4
- --collation-server=utf8mb4_unicode_ci
volumes:
- ./db_data:/var/lib/mysql
restart: always
environment:
MYSQL_ROOT_PASSWORD: somewordpress_wp
MYSQL_DATABASE: wordpress
MYSQL_USER: wordpress
MYSQL_PASSWORD: wordpress
wordpress:
depends_on:
- db_node_domain
image: wordpress:latest
restart: always
environment:
VIRTUAL_HOST: example.test.com
LETSENCRYPT_HOST: example.test.com
DEFAULT_EMAIL: xxx@gmail.com
WORDPRESS_DB_HOST: db_node_domain:3306
WORDPRESS_DB_USER: wordpress
WORDPRESS_DB_PASSWORD: wordpress
networks:
default:
external:
name: nginx-proxy