type
Post
status
Published
slug
2019/08/02/1564718521702.html
summary
tags
Linux
Docker
docker-compose
category
Docker
icon
password
new update day
Property
Oct 22, 2023 01:31 PM
created days
Last edited time
Oct 22, 2023 01:31 PM
0. 前言
记:2019-08-01 我成功的将我
wordpress
的博客给搞坏了(其实主要是插件与主题不兼容的问题、插件 WP.editor
与主题 Asky
,在开启 WP.editor
的兼容模式之后,markdown 代码区块显示出现问题、关闭兼容模式之后主题功能加载异常、emmmm 心塞了)、于是想起以前看到的 solo 这个平台、于是就尝试着迁移过来、多亏我有着保存 md 源文件的习惯、所以在稍加修饰之后就可以直接导入到 solo 内。1. 启动 solo
因为了平时为了备份与迁移方便、所以我的博客大部分都是直接用 docker 启动的,所以就尝试着使用 docker 启动 solo、因为我对
java
一窍不通所以在看 GitHub 上提供的启动参数的时候、确实是一脸懵逼的。1.1. 官方 docker 容器文档
1.1.1 使用 MySQL
# 先手动建库(库名 solo,字符集使用 utf8mb4,排序规则 utf8mb4_general_ci),然后启动容器: docker run --detach --name solo --network=host \\ --env RUNTIME_DB="MYSQL" \\ --env JDBC_USERNAME="root" \\ --env JDBC_PASSWORD="123456" \\ --env JDBC_DRIVER="com.mysql.cj.jdbc.Driver" \\ --env JDBC_URL="jdbc:mysql://127.0.0.1:3306/solo?useUnicode=yes&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC" \\ b3log/solo --listen_port=8080 --server_scheme=http --server_host=localhost --server_port= 为了简单,使用了主机网络模式来连接主机上的 MySQL。
1.1.2 使用 H2 Database
docker run --detach --name solo --volume ~/solo_h2/:/opt/solo/h2/ --publish 8080:8080 \\ --env RUNTIME_DB="H2" \\ --env JDBC_USERNAME="root" \\ --env JDBC_PASSWORD="123456" \\ --env JDBC_DRIVER="org.h2.Driver" \\ --env JDBC_URL="jdbc:h2:/opt/solo/h2/db;MODE=MYSQL" \\ b3log/solo --listen_port=8080 --server_scheme=http --server_host=localhost --server_port=
1.2 分析官方文档
- 官方文档所说为先手动建库、那么如不建库那么会出现什么情况呢?
官方推荐 docker-compose.yaml 如下,可以看出其并没有在容器初始化的时候进行数据库初始化、符合我们的需求
version: "2" services: mysql: container_name: mysql image: mysql:5.5.60 restart: always ports: - "6603:3306" volumes: - ./mysql/data:/var/lib/mysql environment: MYSQL_ROOT_PASSWORD: "adminadmin" command: --max_allowed_packet=32505856 solo: container_name: solo image: b3log/solo:latest restart: always ports: - "8080:8080" environment: RUNTIME_DB: "MYSQL" JDBC_USERNAME: "root" JDBC_PASSWORD: "adminadmin" JDBC_DRIVER: "com.mysql.jdbc.Driver" JDBC_URL: "jdbc:mysql://mysql:3306/solo?useUnicode=yes&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC" command: --listen_port=8080 --server_scheme=http --server_host=(你的域名) --server_port=
启动测试:
docker-compose up # 可以在日志中看到 solo 前端找不到 solo 这个数据库、所以我们需要事先新建好数据库
1.3 改造官方 docker-compsoe 文件
- 查看 docker hub MySQL 镜像介绍 地址🔗
官方提供的镜像是支持通过环境变量在启动的时候新建数据库、以及新建用户和设置密码的。
- 根据文档进行改造
version: "2" services: mysql: container_name: mysql image: mysql:5.5.60 restart: always ports: - "6603:3306" volumes: - ./mysql/data:/var/lib/mysql environment: MYSQL_ROOT_PASSWORD: "adminadmin" MYSQL_USER: "solo" MYSQL_DATABASE: "solo" MYSQL_PASSWORD: "solo" command: --max_allowed_packet=32505856 --character-set-server=utf8mb4 --collation-server=utf8mb4_general_ci solo: container_name: solo image: b3log/solo:latest restart: always ports: - "8080:8080" environment: RUNTIME_DB: "MYSQL" JDBC_USERNAME: "root" JDBC_PASSWORD: "adminadmin" JDBC_DRIVER: "com.mysql.jdbc.Driver" JDBC_URL: "jdbc:mysql://mysql:3306/solo?useUnicode=yes&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC" command: --listen_port=8080 --server_scheme=http --server_host=(你的域名) --server_port=
- 启动测试
docker-compose up # 可以在日志中看到 solo 正常运行等待初始化 solo | [WARN ]-[2019-08-02 11:01:35]-[org.b3log.solo.service.InitService:161]: Solo has not been initialized, please open your browser to init Solo
2. 添加 nginx 反向代理
2.1 docker-compsoe.yaml
version: "2" services: nginx: image: nginx:latest ports: - "80:80" - "443:443" depends_on: - "mysql" volumes: # 虚拟服务器配置文件路径 - ./nginx/conf.d:/etc/nginx/conf.d:ro # nginx 主配置文件 - ./nginx/conf/nginx.conf:/etc/nginx/nginx.conf:ro # 日志路径 - ./nginx/log:/www/wwwlogs:rw # ssl 证书路径 - ./nginx/ssl:/var/www/ssl:rw container_name: "solo-nginx" mysql: image: mysql:5.5.60 restart: always expose: - "3306" volumes: - ./mysql/data:/var/lib/mysql environment: MYSQL_ROOT_PASSWORD: "adminadmin" MYSQL_USER: "solo" MYSQL_DATABASE: "solo" MYSQL_PASSWORD: "solo" command: --max_allowed_packet=32505856 --character-set-server=utf8mb4 --collation-server=utf8mb4_general_ci container_name: "solo-mysql" solo: image: b3log/solo:latest restart: always expose: - "8080" depends_on: - "mysql" links: - "mysql:mysql" environment: RUNTIME_DB: "MYSQL" JDBC_USERNAME: "solo" JDBC_PASSWORD: "solo" JDBC_DRIVER: "com.mysql.jdbc.Driver" JDBC_URL: "jdbc:mysql://mysql:3306/solo?useUnicode=yes&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC" command: --listen_port=8080 --server_scheme=https --server_host=expoli.tech --server_port= container_name: solo
2.2 nginx 主配置文件 nginx.conf
参考我的这篇文档:nginx 主配置文件 nginx.conf 学习
user www-data; pid /var/run/nginx.pid; worker_processes auto; worker_rlimit_nofile 100000; events { worker_connections 2048; multi_accept on; use epoll; } http { server_tokens off; sendfile on; tcp_nopush on; tcp_nodelay on; access_log off; error_log /var/log/nginx/error.log crit; keepalive_timeout 10; client_header_timeout 10; client_body_timeout 10; reset_timedout_connection on; send_timeout 10; limit_conn_zone $binary_remote_addr zone=addr:5m; limit_conn addr 100; include /etc/nginx/mime.types; default_type text/html; charset UTF-8; gzip on; gzip_disable "msie6"; gzip_proxied any; gzip_min_length 1000; gzip_comp_level 6; gzip_types text/plain text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript; open_file_cache max=100000 inactive=20s; open_file_cache_valid 30s; open_file_cache_min_uses 2; open_file_cache_errors on; include /etc/nginx/conf.d/*.conf; include /etc/nginx/sites-enabled/*; }
2.3 nginx 反向代理配置
参考我的这篇文档:nginx+wordpress-docker镜像获取真实IP
server { listen 80; listen 443 ssl http2; server_name expoli.tech; #SSL-START SSL相关配置,请勿删除或修改下一行带注释的404规则 #error_page 404/404.html; #HTTP_TO_HTTPS_START # if ($server_port !~ 443){ # rewrite ^(/.*)$ <https://$host$1> permanent; # } #HTTP_TO_HTTPS_END ssl_certificate /var/www/ssl/www.expoli.tech_nginx/www.expoli.tech.pem; ssl_certificate_key /var/www/ssl/www.expoli.tech_nginx/www.expoli.tech.key; ssl_protocols TLSv1 TLSv1.1 TLSv1.2; ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE; ssl_prefer_server_ciphers on; ssl_session_cache shared:SSL:10m; ssl_session_timeout 10m; error_page 497 https://$host$request_uri; #SSL-END location / { # 保证获取到真实IP proxy_set_header X-Real-IP $remote_addr; # 真实端口号 proxy_set_header X-Real-Port $remote_port; # X-Forwarded-For 是一个 HTTP 扩展头部。 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; # 在多级代理的情况下,记录每次代理之前的客户端真实ip proxy_set_header HTTP_X_FORWARDED_FOR $remote_addr; # 获取到真实协议 proxy_set_header X-Forwarded-Proto $scheme; # 真实主机名 proxy_set_header Host $host; # 设置变量 proxy_set_header X-NginX-Proxy true; proxy_pass <http://solo:8080>; proxy_redirect default; # Socket.IO Support proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; } access_log on; access_log /www/wwwlogs/expoli.tech.log compression; error_log /www/wwwlogs/expoli.tech.error.log; }
3. 优化 docker-compose 配置文件
- 将环境变量由
docker-compose
中转移到隐藏文件中
- 为其指定现有
docker-network
- 挂载出
markdowns
方便进行数据导入与迁移(博客初始化之后、将包含markdown文件的文件夹放入即可、只有存有md文件、删库什么的也不怕了)
3.1 docker-compose.yaml
version: "2" services: nginx: image: nginx:latest ports: - "80:80" - "443:443" depends_on: - "mysql" volumes: - ./nginx/conf.d:/etc/nginx/conf.d:ro - ./nginx/conf/nginx.conf:/etc/nginx/nginx.conf:ro - ./nginx/conf/proxy.conf:/etc/nginx/proxy.conf:ro - ./nginx/log:/www/wwwlogs:rw - ./nginx/ssl:/var/www/ssl:rw container_name: "solo-nginx" mysql: image: mysql:5.5.60 restart: always expose: - "3306" volumes: - ./mysql/data:/var/lib/mysql env_file: - ./.mysql.env command: --max_allowed_packet=32505856 --character-set-server=utf8mb4 --collation-server=utf8mb4_general_ci container_name: "solo-mysql" solo: image: b3log/solo:latest restart: always expose: - "8080" depends_on: - "mysql" links: - "mysql:mysql" volumes: - ./web/markdowns:/opt/solo/markdowns:rw env_file: - ./.solo.env command: --listen_port=8080 --server_scheme=https --server_host=注释:(改为你自己的域名) --server_port= container_name: solo networks: default: external: name: expoli_default_net
3.2 .mysql.env
MYSQL_ROOT_PASSWORD=adminadmin MYSQL_USER=solo MYSQL_DATABASE=solo MYSQL_PASSWORD=solo
3.3 .solo.env
RUNTIME_DB=MYSQL JDBC_USERNAME=solo JDBC_PASSWORD=solo JDBC_DRIVER=com.mysql.jdbc.Driver JDBC_URL=jdbc:mysql://mysql:3306/solo?useUnicode=yes&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC
🆗 配置完成、尽情享受 docker 的便利把!
欢迎加入“喵星计算机技术研究院”,原创技术文章第一时间推送。
- 作者:tangcuyu
- 链接:https://expoli.tech/articles/2019/08/02/1564718521702
- 声明:本文采用 CC BY-NC-SA 4.0 许可协议,转载请注明出处。
相关文章