公司的治理体系是一套有效管理经验集,完全可以迁移到自己的生活中来,以提升生活效率的。比如wiki...so,我们来把wiki部署到自己的服务器上吧...其中涉及到Docker的知识比较多,可以参考上一篇文章...
准备
- 一台服务器(我用的阿里云)
- Docker
- PostgreSQL
- Confluence(破解)
开搞
安装Docker
创建PostgreSQL
docker pull postgreSQL
拉下来官方postgreSQL镜像
开启指令
docker run -d postgres --name postgresdb -p 5432:5432 -e POSTGRES_PASSWORD=W****
参数说明
- 最简指令:
docker run postgres
直接运行postgreSQL这个docker - 后台执行:
-d
- 给运行的docker起个名字:
--name 名字
- 绑定docker端口号和主机端口号:
-p 5432:5432
- 设置环境变量(environment variables):
-e POSTGRES_PASSWORD=数据库密码
运行PostgresDB容器bash
docker exec -it postgresdb bash
参数说明
- 最简指令:
docker exec postgresdb bash
Usage: docker exec [OPTIONS] CONTAINER COMMAND [ARG...] - 说明:交互式容器进程需要通过
-it
创建容器,这两个参数,让docker client 即使和docker进程之间没有直接联系,也能获取其stdin/stdout(标准输入和输出)-
-t
:创建一个 pseudo-TTY,是client和容器进程交换stdin/stdout的关键参考文章 -
-i
:Keep STDIN open even if not attached
-
操作数据库
-
psql -U postgres
文档-
psql
:PostgreSQL interactive terminal -
-U
:指定username
-
-
\l
:同\list
List the databases in the server and show their names, owners, character set encodings, and access privileges -
CREATE DATABASE confluence WITH OWNER postgres;
文档 -
\q
:同\quit
Quits the psql program. In a script file, only execution of that script is terminated.
安装Confluence
docker pull docker.io/cptactionhank/atlassian-confluence
拉CF...不过话说这样拉速度好慢...两个多小时还没拉完...四个小时,拉完了...
启动CF
docker run -d --name confluence -p 8090:8090 --link postgresdb:db --user root:root cptactionhank/atlassian-confluence:latest
启动失败...尝试直接run,发现报错:内存不够...
然后...花了169块大洋😭把阿里云的内存升到2G了...重启,
service docker start
,然后,跑起来了~
记一次数据库容器崩溃及解决方案
之前部署PostgresSQL的时候,木有为数据库绑定Volum...幸好做了CF级别的数据备份,不然所有文档都毁了...
CF备份文件位置
PS. 使用上面提到的docker.io/cptactionhank/atlassian-confluence
image,默认做了Volume挂载,可以通过docker inspect confluence
指令Mount部分,查看到挂载信息
"Mounts": [
{
"Name": "3af40009e8deb5427619b18e77a7395719579f2ee96bc057561214148829de62",
"Source": "/var/lib/docker/volumes/3af40009e8deb5427619b18e77a7395719579f2ee96bc057561214148829de62/_data",
"Destination": "/var/atlassian/confluence",
"Driver": "local",
"Mode": "",
"RW": true,
"Propagation": ""
},
{
"Name": "f6424969404e8a1124da31443babf01ac7460ad41fba7977ae2929e058f30b2b",
"Source": "/var/lib/docker/volumes/f6424969404e8a1124da31443babf01ac7460ad41fba7977ae2929e058f30b2b/_data",
"Destination": "/opt/atlassian/confluence/logs",
"Driver": "local",
"Mode": "",
"RW": true,
"Propagation": ""
}
],
我们可以看到,CF容器的/var/atlassian/confluence
目录,被挂载到了宿主机的/var/lib/docker/volumes/3af40009e8deb5427619b18e77a7395719579f2ee96bc057561214148829de62/_data/backup
目录下
重启postgresdb
这次重启,需要做好容器磁盘的挂载,防止docker挂了导致数据丢失
docker run --name db -p 5432:5432 -e POSTGRES_PASSWORD=x****** -v /var/lib/docker/volumes/postgresql:/var/lib/pgsql/data -d postgres
- -v 指令:指定挂载路径 ,格式为
宿主机路径:容器目录
参考
发现无法启动数据库容器
使用docker logs postgresdb
查看报错原因
The files belonging to this database system will be owned by user "postgres".
This user must also own the server process.
The database cluster will be initialized with locale "en_US.utf8".
The default database encoding has accordingly been set to "UTF8".
The default text search configuration will be set to "english".
Data page checksums are disabled.
fixing permissions on existing directory /var/lib/postgresql/data ... ok
initdb: could not create directory "/var/lib/postgresql/data/pg_wal": No space left on device
initdb: removing contents of data directory "/var/lib/postgresql/data"
磁盘空间不足
联想起前两天阿里云发来的空间使用量超过95%的报警...
基本确定数据库服务挂掉的原因 - 磁盘空间不足
解决方案
使用
-
df -h
查看挂载点的状况 -
du -s -h ./*
查看当前目录文件大小
发现空间占用过多的,是cf的backup文件夹,里面存放了近1年中,每一天的备份文件...尴尬...
删除多余文件,配置自动清理备份文件的指令
备份清理
参考
通过Cron定义自动删除老的备份文件的任务,定期自动运行
vi /etc/cron.daily/deleteOldConfluenceBackups.cron
可以通过man find
查看find指令各参数相关说明
更新Confluence版本
发现时隔一年,confluence已经出了官方docker image了
拉镜像:docker pull atlassian/confluence-server
跑起来:docker run -v /var/lib/docker/volumes/confluence:/var/atlassian/application-data/confluence --name="cf" -d -p 8090:8090 -p 8091:8091 --link db:db --user root:root --env CATALINA_CONNECTOR_PROXYNAME=wiki.daker.wang --env CATALINA_CONNECTOR_PROXYPORT=80 atlassian/confluence-server
云端把Docker中的文件拷到本地准备破解:docker cp cf:/opt/atlassian/confluence/confluence/WEB-INF/lib/atlassian-extras-decoder-v2-3.4.1.jar ./
本地从云端取文件:scp ali-yun:/root/tmp/cf/atlassian-extras-decoder-v2-3.4.1.jar ~/Desktop
改名为:atlassian-extras-2.4.jar
下载:破解包
参考:破解步骤
重启服务:docker cf restart
然后进去做配置就好了...嗯嗯...
Nginx 反向代理处配置
server {
listen 80;
server_name wiki.domain.com;
location / {
client_max_body_size 100m;
proxy_set_header X-Forwarded-Host $host;
proxy_set_header X-Forwarded-Server $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://HOST:PORT;
}
}
参考文档
之后需要修改docker中的tomcat配置文件:/opt/atlassian/confluence/conf/server.xml
<Connector port="8090" scheme="http" proxyName="wiki.daker.wang" proxyPort="80" ...其他属性... />
接着重启tomcat就好
后记
2019.3.25
把wiki迁移到语雀上了...服务器上跑了点别的小东东,内存老报警...
年龄大了,不再痴迷「什么都自己做」了...能达成结果就好...