小知识:Docker实现从零开始搭建SOLO个人博客的方法步骤

目录 一、环境准备 二、安装docker 三、安装mysql主从数据库 3.1、mysql环境准备 3.2、启动mysql主库从库 3.3、登陆mysql主库 3.4、登陆mysql从库 3.5、主从参数说明 四、搭建solo博客 五、nginx实现反向代理solo博客 六、成果展示

一、环境准备

要想在公网访问你的博客,首先你需要一台云服务器,也就是租用各大云厂商的服务器,像我就是花68块买了一年青云的1核2g的服务器,你现在看到的博客就是在这台服务器上,最好也购买一个专属的域名。一年十几就够了。

二、安装docker

%小知识:Docker实现从零开始搭建SOLO个人博客的方法步骤-猿站网-插图

因为我们是用docker部署solo博客。所以我们首先要安装docker,关于docker的介绍请各位同学自行百度。

配置yum源

?
1
2
3
4
sudo yum install -y yum-utils
sudo yum-config-manager \
–add-repo \
http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

安装docker

?
1
sudo yum install -y docker-ce docker-ce-cli containerd.io

启动

?
1
systemctl enable docker –now

配置加速

这里额外添加了docker的生产环境核心配置cgroup

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-eof
{
“registry-mirrors”: [“https://82m9ar63.mirror.aliyuncs.com”],
“exec-opts”: [“native.cgroupdriver=systemd”],
“log-driver”: “json-file”,
“log-opts”: {
“max-size”: “100m”
},
“storage-driver”: “overlay2”
}
eof
sudo systemctl daemon-reload
sudo systemctl restart docker

测试:

输入 docker version 看到如下显示就安装成功了

%小知识:Docker实现从零开始搭建SOLO个人博客的方法步骤-1猿站网-插图

三、安装mysql主从数据库

我们前面已经安装了docker,这里我们直接用命令一键部署mysql数据库(笔者部署的主从的mysql)

3.1、mysql环境准备

?
1
2
mkdir -p /data/master/data/mysql-master  &&  mkdir -p /data/master/data/mysql-slave  ##数据目录
mkdir -p /data/master/master && mkdir -p /data/master/slave ##配置目录

往配置目录分别放两个配置文件,master.cnf slave.cnf 内容分别如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
[root@website master]# cat master/master.cnf
[mysqld]
log-bin=mysql-bin
binlog_format=row
server-id=1
log-error=/var/log/mysqld.log
[root@website master]# cat slave/slave.cnf
[mysqld]
log-bin=mysql-bin
binlog_format=row
server-id=2
log-error=/var/log/mysqld.log

3.2、启动mysql主库从库

注意:这里的密码设置为123456,将mysql的默认数据存放目录映射给了我的/data/master/data

?
1
2
docker run -itd  –name mysql-master -v /data/master/data/mysql-master:/var/lib/mysql -v /data/master/master:/etc/mysql/conf.d -e mysql_root_password=123456 -p 3306:3306 mysql:5.6
docker run -itd –name mysql-slave -v /data/master/data/mysql-slave:/var/lib/mysql -v /data/master/slave:/etc/mysql/conf.d -e mysql_root_password=123456 -p 3316:3306 mysql:5.6

3.3、登陆mysql主库

?
1
2
3
4
5
6
7
8
9
docker ps -a ## 查看两个mysql数据库的状态是否都是up
docker exec -it mysql-master  /bin/bash
mysql -u root -p123456  ## 登陆mysql
show variables like log_bin; ##查看bin-log的开启状态,如果是on代表开启成功,我们主从同步是一定要开binlog
show master status; ## 查询出的file名字与 position要记一下,后面配置从库会用到
## 创建用户并赋权
create user bakup@% identified by 123456;
grant all on *.* to bakup@%;
create database solo;

3.4、登陆mysql从库

?
1
2
3
4
5
docker exec -it mysql-slave  /bin/bash  ## 进入从库
mysql -u root -p123456  ## 登陆mysql
change master to master_host=192.168.1.5, master_port=3306,master_user=bakup,master_password=bakup, master_log_file=mysql-bin.000001,master_log_pos=154;  ##配置主从连接
start slave;  ## 启动从库备份
show slave status\g;  ##查看状态

看到两个yes大功告成!

%小知识:Docker实现从零开始搭建SOLO个人博客的方法步骤-2猿站网-插图

3.5、主从参数说明

master_host:主库的ip地址/服务器地址 master_port:主库的端口 master_user:主库开放出来的用户 master_password:用户的密码 master_log_file:主库的日志文件,二进制日志文件,进行同步的。就是上面show master status 里面的file master_log_pos:上面show master status 里面的position

四、搭建solo博客

前面的准备工作都做完后,就可以开始安装solo了

docker 启动solo
?
1
2
3
4
5
6
7
docker run –detach –name solo      –env runtime_db=”mysql”     –env jdbc_username=”root”     –env jdbc_password=”123456″     –publish 8080:8080     –link mysql-master:mysql-master     –env jdbc_driver=”com.mysql.cj.jdbc.driver”     –env jdbc_url=”jdbc:mysql://192.168.1.5:3306/solo?useunicode=yes&characterencoding=utf-8&usessl=false&servertimezone=utc”     b3log/solo –listen_port=8080 –server_scheme=http –server_host=localhost –server_port=8080
docker logs solo ## 查看容器solo的日志
[info ]-[2021-11-12 18:30:32]-[org.b3log.solo.server:254]: solo is booting [ver=4.3.1, os=linux, isdocker=true, injar=false, luteavailable=false, pid=1, runtimedatabase=mysql, runtimemode=production, jdbc.username=root, jdbc.url=jdbc:mysql://192.168.1.5:3306/solo?useunicode=yes&characterencoding=utf-8&usessl=false&servertimezone=utc]
[info ]-[2021-11-12 18:30:34]-[org.b3log.solo.service.initservice:177]: its your first time setup solo, initialize tables in database [mysql]
[warn ]-[2021-11-12 18:30:36]-[org.b3log.solo.service.initservice:150]: solo has not been initialized, please open your browser to init solo

当出现solo has not been initialized, please open your browser to init solo,代表solo安装成功,但是未进行初始化,可以看到我们前面启动的端口是8080,我们用域名加端口感觉很low,所以我们用nginx去转发一下。

五、nginx实现反向代理solo博客

关于nginx的安装,在这里就不在赘述,同学们可以去百度一哈

上配置文件:
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
http {
sendfile on;
include       mime.types;
default_type  application/octet-stream;
keepalive_timeout  65;
gzip  on;
upstream backend {
server localhost:8080;
}
server {
listen       80;
server_name  yunxue521.top;
location / {
proxy_pass http://backend$request_uri;
proxy_set_header  host $http_host;
proxy_set_header  x-real-ip $remote_addr;
}
}

可以看到我们定义了一个backend的地址指向我们本机的8080端口,nginx监听80端口,当我们去访问80端口时,就会都转发到8080端口,进而实现端口的转发!

六、成果展示

%小知识:Docker实现从零开始搭建SOLO个人博客的方法步骤-3猿站网-插图

到此这篇关于docker实现从零开始搭建solo个人博客的文章就介绍到这了,更多相关docker实现从零开始搭建solo个人博客内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/weixin_43143310/article/details/121309033

声明: 猿站网有关资源均来自网络搜集与网友提供,任何涉及商业盈利目的的均不得使用,否则产生的一切后果将由您自己承担! 本平台资源仅供个人学习交流、测试使用 所有内容请在下载后24小时内删除,制止非法恶意传播,不对任何下载或转载者造成的危害负任何法律责任!也请大家支持、购置正版! 。本站一律禁止以任何方式发布或转载任何违法的相关信息访客发现请向站长举报,会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。本网站的资源部分来源于网络,如有侵权烦请发送邮件至:2697268773@qq.com进行处理。
建站知识

小知识:Docker四步构建MySQL服务

2023-3-14 19:23:04

建站知识

小知识:docker安装RocketMQ的实现步骤

2023-3-14 19:38:00

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索