centos8 安裝python+redis+mysql+nginx
安裝新建coding目錄, 編譯安裝軟件
mkdir /coding
cd coding
1. 編譯安裝 python
- 安裝依賴包
yum install zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel libffi-devel gcc make
- 下載包(華為鏡像)
wget https://mirrors.huaweicloud.com/python/3.8.5/Python-3.8.5.tar.xz
- 解壓
tar -zxvf Python-3.8.5.tar.xz
# 移動到自定義安裝的目錄
mv Python-3.8.5 /coding/py38
cd /coding/py38
- 編譯安裝
./configure --prefix=/coding/py38
make && make install
- 快捷方式
ln -s /coding/py38/bin/python3.8 /usr/bin/python3.8
ln -s /coding/py38/bin/python3.8 /usr/bin/python
ln -s /coding/py38/bin/pip3 /usr/bin/pip3
ln -s /coding/py38/bin/pip3 /usr/bin/pip
- 驗證安裝成功
python --version
pip --version
- yum 依賴的python2.7, 防止yum工作異常
find /usr/bin/ -type f -exec sed -i ':a;N;$!ba;s/\/usr\/bin\/python\([ \n]\)/\/usr\/bin\/python2.7\1/' {} \;
find /usr/libexec/ -type f -exec sed -i ':a;N;$!ba;s/\/usr\/bin\/python\([ \n]\)/\/usr\/bin\/python2.7\1/' {} \;
2. 編譯安裝nginx
- 安裝依賴
yum -y install gcc gcc-c++ autoconf automake make pcre-devel openssl-devel
- 下載包( 華為源)
wget https://mirrors.huaweicloud.com/nginx/nginx-1.21.6.tar.gz
- 解壓包
tar -zxvf nginx-1.21.6.tar.gz
mv nginx-1.21.6.tar.gz /coding/nginx
cd /coding/nginx
- 編譯安裝
./configure --prefix=/coding/nginx
make && make install
- 常用命令
```shell
./nginx //啟動
./nginx -s stop //停止
./nginx -s reload //重載配置
- 查詢啟動
ps -ef | grep nginx
- 創建軟連接
ln -s /coding/nginx/sbin/nginx /usr/local/sbin
nginx //啟動
nginx -s stop //停止
nginx -s reload
- nginx永久加入到系統環境變量
echo 'export NGINX_HOME=/usr/local/nginx' >> /etc/profile
echo 'export PATH=$PATH:$NGINX_HOME/sbin' >> /etc/profile
source /etc/profile
3. 編譯安裝redis
- 安裝依賴
yum -y install gcc gcc-c++ automake autoconf libtool make
- 下載包( 華為源)
wget https://mirrors.huaweicloud.com/redis/redis-6.2.5.tar.gz
- 解壓包
tar -zxvf redis-6.2.5.tar.gz
mv redis-6.2.5 /coding/redis
cd /coding/redis
- 編譯安裝
make PREFIX=/coding/redis install
- 測試安裝結果
make test
- 配置文件說明(redis.conf)
- 過濾注釋行和空行:
grep -v ^# redis.conf | grep -v ^$
- 過濾注釋行和空行:
bind 127.0.0.1 # 綁定IP
protected-mode yes
port 6379 # 端口
tcp-backlog 511
timeout 0
tcp-keepalive 300
daemonize no # 守護進程
supervised no
pidfile /var/run/redis_6379.pid
loglevel notice
logfile ""
databases 16
always-show-logo yes
# rdb 數據持久化( 保存操作到本地文件)
# 觸發持久化, 每900s 超過一次更改,就保存,
save 900 1 # 經過900s, 超過1次,保存,以此類推
save 300 10
save 60 10000
stop-writes-on-bgsave-error yes
rdbcompression yes
rdbchecksum yes
dbfilename dump.rdb # 保存rdb文件
rdb-del-sync-files no
dir ./ # rdb 保存rdb目錄
replica-serve-stale-data yes
replica-read-only yes
repl-diskless-sync no
repl-diskless-sync-delay 5
repl-diskless-load disabled
repl-disable-tcp-nodelay no
replica-priority 100
acllog-max-len 128
lazyfree-lazy-eviction no
lazyfree-lazy-expire no
lazyfree-lazy-server-del no
replica-lazy-flush no
lazyfree-lazy-user-del no
oom-score-adj no
oom-score-adj-values 0 200 800
# aof 數據持久化( 保存操作到本地文件)
appendonly no # 默認關閉
appendfilename "appendonly.aof" #本地數據庫文件名
appendfsync everysec # 寫入頻率 可設置always 和 no
no-appendfsync-on-rewrite no
# aof 重寫觸發
auto-aof-rewrite-percentage 100
auto-aof-rewrite-min-size 64mb
#
aof-load-truncated yes
aof-use-rdb-preamble yes
lua-time-limit 5000
slowlog-log-slower-than 10000
slowlog-max-len 128
latency-monitor-threshold 0
notify-keyspace-events ""
hash-max-ziplist-entries 512
hash-max-ziplist-value 64
list-max-ziplist-size -2
list-compress-depth 0
set-max-intset-entries 512
zset-max-ziplist-entries 128
zset-max-ziplist-value 64
hll-sparse-max-bytes 3000
stream-node-max-bytes 4096
stream-node-max-entries 100
activerehashing yes
client-output-buffer-limit normal 0 0 0
client-output-buffer-limit replica 256mb 64mb 60
client-output-buffer-limit pubsub 32mb 8mb 60
hz 10
dynamic-hz yes
aof-rewrite-incremental-fsync yes
rdb-save-incremental-fsync yes
jemalloc-bg-thread yes
- 開啟服務端:
./redis-server - 客戶端訪問:
./redis-cli - 修改自啟文件權限:
chmod 775 /etc/init.d/redis - 設置自啟:
chkconfig redis on
4. 安裝mysql
參考:[centos8安裝mysql8.0.22教程](https://blog.csdn.net/qq_39150374/article/details/112471108)
下載包(rpm)
wget https://dev.mysql.com/get/mysql80-community-release-el8-1.noarch.rpm
yum install mysql80-community-release-el8-1.noarch.rpm
檢查數據源:
yum repolist enabled | grep "mysql.*-community.*"
錯誤: No match for argument: mysql-community-server
解決方法:yum module disable mysql
安裝 MYSQL 命令
yum install mysql-community-server
錯誤:Error:GPG check FAILED
解決方法:yum 安裝時添加 --nogpgcheck 參數
yum -y install xx --nogpgcheck
啟動服務
genie -s # 在wsl子系統中實現systemd
systemctl start mysqld
顯示MySQL臨時密碼
grep 'temporary password' /var/log/mysqld.log
輸出: 2022-03-14T02:26:55.430178Z 6 [Note] [MY-010454] [Server] A temporary password is generated for root@localhost: 33HnSqi/jFK#
登錄
mysql -u root -p //輸入上面生成的密碼
密碼修改
mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY 'Root_21root';
錯誤 ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
解決辦法:
一定要先修改默認密碼為: Root_21root 滿足它的策略,再進行下面的操作:
# 查看密碼策略
mysql> SHOW VARIABLES LIKE 'validate_password%';
# 修改密碼長度:
mysql> set global validate_password.length=1;
# 修改密碼等級:
mysql> set global validate_password.policy=0;
# 設置成自己想要的密碼:
ALTER USER 'root'@'localhost' IDENTIFIED BY '123456';
開放遠程訪問
# 1、先創建權限記錄
mysql> create user 'root'@'%' identified by 'root123';
# 2、授權
mysql> grant all privileges on *.* to 'root'@'%' with grant option;
更改加密方式
mysql> use mysql;
mysql> select user,plugin from user where user='root';
# 將用戶的加密方式改為mysql_native_password。
mysql> alter user 'root'@'%' identified with mysql_native_password by 'Admin@123';
# 使權限配置項立即生效。
mysql> flush privileges;
解決錯誤:2059 - Authentication plugin ‘caching_sha2_password’ cannot be loaded:centos8 安裝python+redis+mysql+nginx

浙公網安備 33010602011771號