这篇文章上次修改于 1517 天前,可能其部分内容已经发生变化,如有疑问可询问作者。

CentOS7 初始化设置&安装Python3.7

curl http://mirrors.aliyun.com/repo/Centos-7.repo >>Centos-7.repo
cd /etc/yum.repos.d/
mv  CentOs-Base.repo CentOs-Base.repo.bak
cp ~/Centos-7.repo CentOS-Base.repo
yum clean all
yum update -y
sudo yum makecache
sudo yum install epel-release
sudo sed -e 's!^metalink=!#metalink=!g'     -e 's!^#baseurl=!baseurl=!g'     -e 's!//download\.fedoraproject\.org/pub!//mirrors.tuna.tsinghua.edu.cn!g'     -e 's!http://mirrors\.tuna!https://mirrors.tuna!g'     -i /etc/yum.repos.d/epel.repo /etc/yum.repos.d/epel-testing.repo

安装Python

yum install zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel gcc make -y
wget https://www.python.org/ftp/python/3.7.7/Python-3.7.7.tar.xz
tar xvf Python-3.7.0.tar.xz 
cd Python-3.7.0/

./configure\
  prefix=/usr/local/python3\
    --with-ssl \
    --enable-shared

make && make install
[root@192 Python-3.7.7]# ln -s /usr/local/python3/bin/python3 /usr/local/bin/python3
[root@192 Python-3.7.7]# ln -s /usr/local/python3/bin/pip3 /usr/local/bin/pip3
[root@192 Python-3.7.7]# python3
python3: error while loading shared libraries: libpython3.7m.so.1.0: cannot open shared object file: No such file or directory
[root@192 Python-3.7.7]# cp libpython3.* /usr/local/lib64/
[root@192 Python-3.7.7]# cp libpython3.* /usr/lib/
[root@192 Python-3.7.7]# cp libpython3.* /usr/lib64/

安装docker和命令补齐

准备工作
系统要求
Docker 支持 64 位版本 CentOS 7/8,并且要求内核版本不低于 3.10。 CentOS 7 满足最低内核的要求,但由于内核版本比较低,部分功能(如 overlay2 存储层驱动)无法使用,并且部分功能可能不太稳定。
卸载旧版本
旧版本的 Docker 称为 docker 或者 docker-engine,使用以下命令卸载旧版本:
$ sudo yum remove docker \
                  docker-client \
                  docker-client-latest \
                  docker-common \
                  docker-latest \
                  docker-latest-logrotate \
                  docker-logrotate \
                  docker-selinux \
                  docker-engine-selinux \
                  docker-engine
使用 yum 安装
执行以下命令安装依赖包:
$ sudo yum install -y yum-utils
鉴于国内网络问题,强烈建议使用国内源,官方源请在注释中查看。
执行下面的命令添加 yum 软件源:
$ sudo yum-config-manager \
    --add-repo \
    https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

$ sudo sed -i 's/download.docker.com/mirrors.aliyun.com\/docker-ce/g' /etc/yum.repos.d/docker-ce.repo

# 官方源
# $ sudo yum-config-manager \
#     --add-repo \
#     https://download.docker.com/linux/centos/docker-ce.repo
如果需要测试版本的 Docker (或你的系统是 CentOS 8)请执行以下命令:
$ sudo yum-config-manager --enable docker-ce-test
安装 Docker
更新 yum 软件源缓存,并安装 docker-ce。
$ sudo yum install docker-ce docker-ce-cli containerd.io

启动 Docker
$ sudo systemctl enable docker
$ sudo systemctl start docker

建立 docker 用户组
默认情况下,docker 命令会使用 Unix socket 与 Docker 引擎通讯。而只有 root 用户和 docker 组的用户才可以访问 Docker 引擎的 Unix socket。出于安全考虑,一般 Linux 系统上不会直接使用 root 用户。因此,更好地做法是将需要使用 docker 的用户加入 docker 用户组。
建立 docker 组:
$ sudo groupadd docker
将当前用户加入 docker 组:
$ sudo usermod -aG docker $USER
退出当前终端并重新登录,进行如下测试。

CentOS8 额外设置
由于 CentOS8 防火墙使用了 nftables,但 Docker 尚未支持 nftables, 我们可以使用如下设置使用 iptables:
更改 /etc/firewalld/firewalld.conf
# FirewallBackend=nftables
FirewallBackend=iptables
或者执行如下命令:
$ firewall-cmd --permanent --zone=trusted --add-interface=docker0

$ firewall-cmd --reload

docker告警

添加内核参数
如果在 CentOS 使用 Docker 看到下面的这些警告信息:
WARNING: bridge-nf-call-iptables is disabled
WARNING: bridge-nf-call-ip6tables is disabled
请添加内核配置参数以启用这些功能。
$ sudo tee -a /etc/sysctl.conf <<-EOF
net.bridge.bridge-nf-call-ip6tables = 1
net.bridge.bridge-nf-call-iptables = 1
EOF
然后重新加载 sysctl.conf 即可
$ sudo sysctl -p

完善TAB补齐功能

yum -y install bash-completion
sudo curl -L https://raw.githubusercontent.com/docker/docker/v$(docker version -f "{{.Client.Version}}")/contrib/completion/bash/docker -o /etc/bash_completion.d/docker

安装docker命令自动补全
sudo curl -L https://raw.githubusercontent.com/docker/docker/v$(docker version -f "{{.Client.Version}}")/contrib/completion/bash/docker -o /etc/bash_completion.d/docker
安装docker-compose命令自动补全
sudo curl -L https://raw.githubusercontent.com/docker/compose/$(docker-compose version --short)/contrib/completion/bash/docker-compose -o /etc/bash_completion.d/docker-compose
修改~/.bash_profile
vim ~/.bash_profile
# 添加如下内容
[ -f /etc/bash_completion.d ] && . /etc/bash_completion.d
设置使其生效
source ~/.bash_profile