first commit
This commit is contained in:
@@ -1 +1,32 @@
|
||||
# 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的数据卷没有自定义挂载,需要操作数据卷的朋友可以参照这篇
|
||||
|
||||
|
||||
@@ -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
@@ -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;
|
||||
}
|
||||
}
|
||||
@@ -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
|
||||
@@ -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
|
||||
@@ -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
|
||||
@@ -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;
|
||||
}
|
||||
}
|
||||
@@ -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
|
||||
@@ -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
|
||||
@@ -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
|
||||
Reference in New Issue
Block a user