“CentOS”的版本间的差异
(→CentOS防火墙设置) |
|||
第145行: | 第145行: | ||
=CentOS防火墙设置= | =CentOS防火墙设置= | ||
− | + | # 防火墙一般命令 | |
− | yum install firewalld | + | #: yum install firewalld #查看已经安装的firewall文件 |
− | service firewalld start | + | #: service firewalld start |
− | service firewalld stop/disable | + | #: service firewalld stop/disable |
− | ps -ef |grep firewall | + | #: ps -ef |grep firewall #查看当前firewall运行的进程 |
+ | #: service firewalld restart #重启防火墙 | ||
+ | #: service firewalld status #查看防火墙的状况 | ||
+ | #: firewall-cmd --version #查看版本 | ||
+ | #: firewall-cmd --get-zones #查看防火墙区域 | ||
+ | #: firewall-cmd --get-default-zone #查看防火墙的默认空间 | ||
+ | #: firewall-cmd --list-all-zones #查看所有空间的配置信息 | ||
+ | #: firewall-cmd --list-all # 查看防火墙规则 | ||
+ | # 查询、开放、关闭端口 | ||
+ | #: firewall-cmd --query-port=8080/tcp # 查询端口是否开放 | ||
+ | #: firewall-cmd --permanent --add-port=80/tcp # 开放80端口 | ||
+ | #: firewall-cmd --permanent --remove-port=8080/tcp # 移除端口 | ||
+ | #: firewall-cmd --reload #重启防火墙(修改配置后要重启防火墙) | ||
+ | # 参数解释 | ||
+ | ## firwall-cmd:是Linux提供的操作firewall的一个工具; | ||
+ | ## --permanent:表示设置为持久; | ||
+ | ## --add-port:标识添加的端口; |
2019年9月12日 (四) 14:34的版本
基于CentOS7.4的服务器搭建笔记,记录起始于:2019/9/10 @ 浙江嘉兴
目录
[隐藏]GUI切换Terminal
- Ctrl+alt+F1~F6 从图形登陆界面切换到dos界面;
- 界面切换到命令行界面输入 init 3 命令;
- 命令行界面切换到图形界面输入 init 5 命令;
centos下修改文件后如何保存退出
保存命令,按ESC键 跳到命令模式,然后:
- :w 保存文件但不退出vi
- :w file 将修改另外保存到file中,不退出vi
- :w! 强制保存,不推出vi
- :wq 保存文件并退出vi
- :wq! 强制保存文件,并退出vi
- :q 不保存文件,退出vi
- :q! 不保存文件,强制退出vi
- :e! 放弃所有修改,从上次保存文件开始再编辑
yum clean all大坑解决
- 在Centos7系统中执行yum clean all 之后,发现yum的其他执行都报错了;要解决,关键在这里:
- 把/var/cache/yum/ 下面的文件删除了
- 接下来,如果执行yum repolist all,结果为0;执行yum list正常的话,那就是/etc/yum.repos.d/*.repo 这货有问题啦,解决这货的问题
- 执行 yum makecache 然后再执行yum update
- OK
- yum仓库的命令:
- yum repolist 列出yum仓库
- yum clean all 清理yum 缓存
- yum makecache 缓存yum仓库
PHP extension冲突问题(如:php70w 与 php-common < 7.0的冲突)
一般情况下是发生在PHP升级情况下,php核心和扩展多版本共存,版本发生冲突情况下的警告,可能导致php环境运行异常
- PHP7极大地改进了性能,在一些WordPress基准测试当中,性能可以达到PHP 5.6的3倍。
- 使用Yum安装PHP有两个源可以选择,一个是webtatic提供的,也就是php70w,那个w指得就是webtatic,另一个可以使用remi源。
- yum install epel-release
- rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm
- yum update
- yum list | grep php # 罗列yum源可安装包
- 另一种做法,移除php-common
- yum remove php-common # 再次执行
- yum -y install php70w-devel
- 使用yum install命令安装,如果直接yum install php,安装的PHP版本是5.6,要安装高版本的PHP,其实也可以用yum install命令直接安装
- 安装之前先卸载虚拟机上其他版本的PHP
- yum -y remove php*
- 由于linux的yum源不存在PHP7.x,所有我们要改yum源(两条命令)
- 安装PHP及其扩展,比如安装php7.2
- yum -y install php72w php72w-cli php72w-common php72w-devel php72w-embedded php72w-fpm php72w-gd php72w-mbstring php72w-mysqlnd php72w-opcache php72w-pdo php72w-xml
- 安装完成后,php -v查看安装的PHP版本,版本号正确,说明PHP安装成功
修改php.ini 解决mbstring扩展异常
- yum install php-mbstring # 如果是remi,则yum --enablerepo=remi install php-mbstring
- vim /etc/php.ini # 打开mbstring相关的选项。
[mbstring] language for internal character representation. http://php.net/mbstring.language mbstring.language = Chinese
internal/script encoding. Some encoding cannot work as internal encoding. (e.g. SJIS, BIG5, ISO-2022-*) http://php.net/mbstring.internal-encoding mbstring.internal_encoding = UTF-8
http input encoding. http://php.net/mbstring.http-input mbstring.http_input = auto
http output encoding. mb_output_handler must be registered as output buffer to function http://php.net/mbstring.http-output
mbstring.http_output = UTF-8
enable automatic encoding translation according to mbstring.internal_encoding setting. Input chars are converted to internal encoding by setting this to On. Note: Do _not_ use automatic encoding translation for portable libs/applications. http://php.net/mbstring.encoding-translation mbstring.encoding_translation = On
CentOS下版本查询及手工修改路径案例
- 可用命令参考
- php -v
- httpd -v
- rpm -qa |grep php
- rpm -qa |grep httpd
- php -m # 查看下加载情况
- 案例:查找系统里PHP相关的目录或文件并手工修改profile
- find / -name php # 查看列出的 PHP 版本的信息
- /usr/bin/php -v # // PHP 5.4.45
- /usr/local/php/bin/php -v # // PHP 7.2.18
- 删除 /usr/bin/ 目录下的所有PHP相关的目录或文件
- rm -rf ./php
- rm -rf ./php-cgi
- rm -rf ./php-config
- rm -rf ./phpize
- 环境变量中添加自己编译的 PHP 的路径
- vim /etc/profile
- Shift + G 定位到最后一行,添加自己编译的 PHP 的路径
- export PATH="/usr/local/php/bin:$PATH"
- 保存退出,执行
- source /etc/profile
- 再次检查 PHP 版本
- php -v
- 通过yum安装PHP7
- rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm
- yum -y install php70w-devel
- 报错冲突了
- --> Finished Dependency Resolution
- Error: php70w-common conflicts with php-common-5.4.16-43.el7_4.x86_64
- You could try using --skip-broken to work around the problem
- You could try running: rpm -Va --nofiles --nodigest
- 移除php-common
- yum remove php-common
- 再次执行
- yum -y install php70w-devel
- 成功!!!
find: ‘/run/user/1000/gvfs’: 权限不够 的解决办法
官方说这是一个bug[bug#615848],原因是FUSE文件系统和权限不配的问题,全局搜索时碰到它就会退出报错。 其实这个目录是空的,查不查都没关系。所以,以下解决方式比较简粗暴:
umount /run/user/1000/gvfs // 卸载该文件 rm -rf /run/user/1000/gvfs // 删除该文件
php版本升级或者更改后发生httpd服务异常的问题处理
apache不知道php版本已更改,因此php网页用不了apache也就是httpd。
- 比如在/var/www/html/目录下建立一个info.php文件,该目录是网页的根目录,也就是在浏览器中访问:IP/info.php即可出现info.php的内容。
- info.php文件如下:
- sudo vim /etc/www/html/info.php
- <?php phpinfo();?>
- 在浏览器输入IP/info.php,发现找不到该页面。因为说过apache不知道我们改了php版本,导致解析失败。
- 因此为了让apache支持php7.2,需要修改apache的配置文件:
- 首先,找到php的配置文件:php.ini,利用find命令:
- sudo find / -name php.ini # 通常情况下位于/etc中,也就是/etc/php.ini。
- 然后找到apache的配置文件:httpd.conf
- sudo find / -name httpd.conf # 位置如下:/etc/httpd/conf/httpd.conf
- 然后修改该文件,在该文件最后一行加上:
- PHPIniDir /etc/php.ini # 表示告诉apache,php的配置信息文件。
- 保存即可,然后重新在浏览器中输入IP/info.php,页面内容正常即表示成功!
- 可以使用如下命令查询httpd状态:
- systemctl status httpd.service -l
CentOS防火墙设置
- 防火墙一般命令
- yum install firewalld #查看已经安装的firewall文件
- service firewalld start
- service firewalld stop/disable
- ps -ef |grep firewall #查看当前firewall运行的进程
- service firewalld restart #重启防火墙
- service firewalld status #查看防火墙的状况
- firewall-cmd --version #查看版本
- firewall-cmd --get-zones #查看防火墙区域
- firewall-cmd --get-default-zone #查看防火墙的默认空间
- firewall-cmd --list-all-zones #查看所有空间的配置信息
- firewall-cmd --list-all # 查看防火墙规则
- 查询、开放、关闭端口
- firewall-cmd --query-port=8080/tcp # 查询端口是否开放
- firewall-cmd --permanent --add-port=80/tcp # 开放80端口
- firewall-cmd --permanent --remove-port=8080/tcp # 移除端口
- firewall-cmd --reload #重启防火墙(修改配置后要重启防火墙)
- 参数解释
- firwall-cmd:是Linux提供的操作firewall的一个工具;
- --permanent:表示设置为持久;
- --add-port:标识添加的端口;