一、背景
碰上个很CD的问题,中心的服务团队只给维护Windows系统及相关配置,任何Linux相关的系统或软件,想用可以,但必须个人去安装、维护,没办法,鉴于服务器环境下Linux系统的明显优点,只能厚着脸皮自己搞了:CentOS7 + Docker + Postgres10.0
注:自己以前从未搞过服务器配置相关,都是专人负责,所以在整个操作的过程中也是遇到了很多这那的问题,也填了很多坑,但最终顺利完成,仅此记录,给有需要的朋友以借鉴!
操作流程
准备U盘安装工具,制作U盘镜像
安装CentOS 7系统
网络配置
防火墙配置
安装Docker
安装postgresql数据库
运行+备份数据库
二、系统安装
制作U盘镜像
注:建议U盘容量至少64G,否则可能会因为容量不足导致制作失败
安装
本文安装的是CentOS7系统,其他版本系统安装大同小异。
安装过程可参考CentOS7安装教程,相关的一系列操作、配置都有涉及,文中还涉及到了部分网络配置相关,但这块与我的操作出入很大,就不多赘述。
这步结束之后,CentOS系统就算安装成功了,剩下的就是各种配置
网络配置
进行网络配置前首先得明确:
- 服务器是否已连接网络
- 连接的是服务器上哪个网卡
- 保证网络正常
-
先用
ifconfig
查看连接的是哪个网卡,只有被连接网线的才会出现ip信息,如图,我连接的是em4
网卡,记住em4
:
进入
/etc/sysconfig/network-scripts/
文件夹下,编辑ifcfg-em4
# vi /etc/sysconfig/network-scripts/ifcfg-em4
NM_CONTROLLED=no //原来没有加上的
TYPE=Ethernet
BOOTPROTO=static //如果是动态IP,此处改成dhcp
DEFROUTE=yes
PEERDNS=yes
PEERROUTES=yes
IPV4_FAILURE_FATAL=yes //no改成yes
IPV6INIT=yes
IPV6_AUTOCONF=yes
IPV6_DEFROUTE=yes
IPV6_PEERDNS=yes
IPV6_PEERROUTES=yes
IPV6_FAILURE_FATAL=no
IPV6_ADDR_GEN_MODE=stable-privacy
NAME=em4
UUID=851ae637-14d4-4435-9c38-d3a3e4c2f0c3 // 这里对应你网卡的mac地址
DEVICE=ens3
IPADDR=192.168.5.214 //上图提示的IP,而非主机IP
NETMASK=255.255.255.0 //上图显示的子网掩码
GATEWAY=192.168.5.2 //上图显示的网关
ONBOOT=yes //no改成yes,表明系统启动时就激活网卡
编辑完成后保存,然后重启网络服务让其生效
// 重启服务
systemctl restart network
// 将服务加到开机自启动中
systemctl enable network
网络配置失败问题分析
-
重启服务失败
:如果一直restart
失败,那您就可以直接重启下服务器了,至少我是这么解决的 -
所有配置信息都配置了,网络还是不通
:考虑是否是公司网络限制问题,有的公司网络需要拨号上网,或需要身份验证,这种情况可以咨询公司网络团队,然后在系统-设置-network-em4-802.X
中配置下参数
防火墙端口配置
配置防火墙端口主要是方便对服务器进行外部访问,当然,嫌事少的,也可以把防火墙直接关闭,这样就可以访问服务器上的任何端口了。
# 1. 在public区域开放一个端口13579
firewall-cmd --zone=public --add-port=13579/tcp --permanent
# 2. 使配置生效
firewall-cmd --reload
# 3. 查看
firewall-cmd --list-ports
三、开发环境配置
文中涉及到的软件环境皆有Docker安装
安装Docker
1. 查看Linux内核版本是否支持待安装Docker版本
$ uname -a
2. (可选)升级yum包到最新(生产环境慎用,会对软件包和内核升级)
$ yum update
3. 安装需要的软件包,yum-util
提供yum-config-manager
功能,另外两个是devicemapper
驱动依赖的
$ yuam install -y yum-utils device-mapper-persistent-data lvm2
4. 设置yum源
$ yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
5. 查看仓库中所有的docker版本,选择特定版本安装
$ yum list docker-ce --showduplicates | sort -r
6. 安装docker
// yum install docker-ce-版本号,如下
$ yum install docker-ce-18.03.1.ce-1.el7.centos
7. 启动docker
// 启动docker
$ systemctl start docker
// 开机启动
$ systemctl enable docker
//
8. 验证安装是否成功
$ docker version
用Docker安装Postgres数据库
1. 查看postgres可用镜像
docker search postgres
2. 拉取postgres镜像
# 拉取镜像
docker pull postgres:10.0
# 查看镜像安装状态
docker images
3. 创建容器(普通创建)
# 创建普通镜像容器
docker run --name postgresql -e POSTGRES_PASSWORD=password -p 5432:5432 -d postgres:10.0
# 创建容器(宿主机挂载)
docker run -p 5432:5432 --name postgresql -e POSTGRES_PASSWORD=password -v host_filePath:container_filePath -d postgres:10.0
run
:创建并运行一个容器
--name
:指定容器名称
-e
:指定容器内的环境变量,此处是配置数据库密码,一条指令可以同时连接多个-e
参数
-p
:指定容器端口与主机端口的映射关系 主机端口:容器端口
-d
:指定后台运行
-v
:将容器内指定目录挂载到宿主机上
postgres:10.0
:指定镜像版本
host_filePath
:宿主机目录
container_filePath
:容器内目录
注:postgres镜像默认的用户名为postgres,登录口令为创建容器时指定的值
4. 查看容器运行状态
docker ps -a
-
Up
:正在运行 -
Exited
:已退出
5. 外网测试数据库是否创建成功
此处是用
DataGrip
测试的数据库连接,如图,与数据库连接成功,证明数据库创建成功
6. 数据库备份
-
备份
:容器内打包dmp文件 , 将dmp文件导出到宿主机上 -
还原
:将dmp文件由宿主机导入到容器内 , 容器中执行指令还原
# 1. 链接容器
docker exec -it <containerID> /bin/bash
# 2. 导出整个库
# 将localhost下数据库名为db_name,用户名为postgres ,
# 数据库端口号为5432的数据库导出到 容器/var/backups/db_name.dmp中
pg_dump -h localhost -U postgres -p 5432 db_name > /var/backups/db_name.dmp
# 3. 数据还原
psql -h localhost -U postgres -p 5432 db_name < /var/backups/db_name.dmp
容器文件与宿主机文件相互拷贝
# 1. 将主机/root/backups目录拷贝到容器3fcacc8a8c04的/var目录下。
docker cp /root/backups 3fcacc8a8c04:/var/
#2. 将容器3fcacc8a8c04的/var/backups目录拷贝到主机的/root/backups目录中。
docker cp 3fcacc8a8c04:/var/backups /root/backups