EAimTY 的博客
肥宅
首页
关于
主题
记录一下重装服务器系统中遇到的一堆坑
Aug 08, 2017

很长一段时间以来,博主用的 Vultr2.5 刀小机上的 MySQL5.7 频繁抽风,经常需要手动重启服务器,至于为什么这么长时间没有管它,原因还是我懒呗~

最近闲了下来,有时间折腾一下服务器了,于是重装了一下换回 MySQL5.5,用 CentOS 官方镜像重装了系统。
之前因为听说 SELinux 和 Systemd 之间不容易和谐共处,所以都是关掉 SELinux 的(不要学我,这很不安全)。
这次用 CentOS7 1611 x64 Minimal 官方镜像中 SELinux 是默认打开的,试了一下,发现不是想象中的那么差,所以就没有关闭。
接下来,坑就来了。

坑一

更换 SSH 端口后,从外界无法连接

解决方法:

根据 sshd_config 中给出的方法,在文件中修改端口号后需要告诉 SELinux,运行 # semanage port -a -t ssh_port_t -p tcp 端口号

坑二

semanage command not found

解决方法

查一下命令所在包:# yum provides semanage

得知命令存在于包policycoreutils-python

安装包:# yum install policycoreutils-python

坑三

nginx 读不到配置文件、证书,网站目录

解决方法

SELinux 有个限制:cp instead mv

在折腾好文件后,执行 # restorecon -v -R /path/to/files

坑四

网站 conf、证书、文件都到位后访问显示files not exist

解决方法

还是 SELinux 的锅

告诉 SELinux 这是网站的文件:# chcon -Rt httpd_sys_content_t /path/to/www
如需通过网页程序修改文件内容,则是:# chcon -Rt httpd_sys_content_rw_t /path/to/writabledir

坑五

可通过 ip 直接经过 443 端口访问网站

解决方法

我的站点都是有 SSL 的,所以一般都会在 iptables 中禁掉 80 端口,所以咱们只需要折腾一下 443 端口的问题
Google 到的结果中有一堆放在 CSDN、博客园之类的文章,你抄我,我抄你,而且抄的还都有问题,真 TM 是恶心透了。

最终找到了解决方案:

在 nginx.conf 中的 include /etc/nginx/conf.d/*.conf; 一行下面插入:

server {
    listen  443 default;
    return  444;
    ssl_certificate /path/to/crt;
    ssl_certificate_key /path/to/key;
}

这里的证书自己签一个就好,注意不要在其中泄露真是的网站信息。

respond-post-24
Benny
Aug 09, 2017, 16:19

😂SELinux,背锅侠

RVIER
RVIER
Oct 14, 2017, 18:26

“你抄我,我抄你,而且抄的还都有问题” 哈哈哈哈哈哈哈嗝儿

添加新评论

请填写称呼
请填写合法的电子邮箱地址
请填写合法的网站地址
请填写内容