成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

SELinux 權限問題導致 GreatSQL 運行不了的坑

系統 Linux
安全增強型 Linux(SELinux)是一種采用安全架構的 Linux? 系統,它能夠讓管理員更好地管控哪些人可以訪問系統。它最初是作為 Linux 內核的一系列補丁,由美國國家安全局(NSA)利用 Linux 安全模塊(LSM)開發而成。

系統版本:Linux version 4.18.0-348.el8.x86_64

前言

SELinux 是什么

安全增強型 Linux(SELinux)是一種采用安全架構的 Linux? 系統,它能夠讓管理員更好地管控哪些人可以訪問系統。它最初是作為 Linux 內核的一系列補丁,由美國國家安全局(NSA)利用 Linux 安全模塊(LSM)開發而成。

SELinux 工作原理

SELinux 定義了每個人對系統上的應用、進程和文件的訪問控制。利用安全策略(一組告知 SELinux 哪些能訪問,哪些不能訪問的規則)來強制執行策略所允許的訪問。

當應用或進程(稱為主體)發出訪問對象(如文件)的請求時,SELinux 會檢查訪問向量緩存(AVC),其中緩存有主體和對象的訪問權限。

開啟 SELinux 可以提升系統的安全性,但同時也會帶來一些問題。在特定場景有的人會選擇關閉 SELinux 以換取更好的兼容性。

在GreatSQL的安裝手冊里,就有關閉 SELinux 這一步。

#關閉selinux
$ setenforce 0
$ sed -i '/^SELINUX=/c'SELINUX=disabled /etc/selinux/config

不禁讓人好奇,這個 SELinux 安全模塊,如果不關閉會產生什么問題,在使用時有哪些需要注意的地方。于是我特意嘗試了一下,開啟 SELinux 安裝 GreatSQL 數據庫,看看會出現哪些問題。

問題產生

為了發現問題,我特意選擇在用戶目錄(/root)下載解壓  GreatSQL 二進制壓縮包,然后再移動到指定目錄使用。

cd /root
wegt https://***.***/greatsql.tar.gz
tar -xvf greatsql.tar.gz
mv /root/greatsql /usr/local/

安裝過程一切順利,數據庫正常啟動了,但是在配置 systemd 進程守護的時候出現了問題。

greatsql.service文件:

vim /usr/lib/systemd/system/greatsql.service

[Unit]
Description=GreatSQL Server
After=network.target
After=syslog.target

[Install]
WantedBy=multi-user.target

[Service]
User=greatsql
Group=User=greatsql

# Have mysqld write its state to the systemd notify socket
Type=notify
# Disable service start and stop timeout logic of systemd for mysqld service.
TimeoutSec=0
# Start main service
ExecStart=/usr/local/mysql/bin/mysqld --defaults-file=/etc/my.cnf $MYSQLD_OPTS
# Use this to switch malloc implementation
#EnvironmentFile=-/etc/sysconfig/mysql
# Sets open_files_limit
LimitNOFILE = 10000

Restart=on-failure

RestartPreventExitStatus=1
# Set environment variable MYSQLD_PARENT_PID. This is required for restart.
Environment=MYSQLD_PARENT_PID=1

PrivateTmp=false

用  systemctl start greatsql 啟動數據庫的時候報以下錯誤。

[root@Linux ~]# systemctl restart greatsql
Job for greatsql.service failed because the control process exited with error code.
See "systemctl status greatsql.service" and "journalctl -xe" for details.

直接運行mysqld?沒問題但是使用systemctl 就啟動不了。

根據上面的報錯,查看一下 greatsql systemd的狀態和相關日志

[root@gip Linux]# systemctl status greatsql.service
● greatsql.service
Loaded: loaded (/usr/lib/systemd/system/greatsql.service; bad; vendor preset: disabled)
Active: failed (Result: exit-code) since Tue 2023-01-10 16:00:06 CST; 17s ago
Process: 147226 ExecStart=/usr/local/greatsql/bin/mysqld --defaults-file=/etc/my.cnf $MYSQLD_OPTS (code=exited, status=203/EXEC)
Main PID: 147226 (code=exited, status=203/EXEC)

Jan 10 16:00:06 gip systemd[1]: greatsql.service: Service RestartSec=100ms expired, scheduling restart.
Jan 10 16:00:06 gip systemd[1]: greatsql.service: Scheduled restart job, restart counter is at 5.
Jan 10 16:00:06 gip systemd[1]: Stopped greatsql.service.
Jan 10 16:00:06 gip systemd[1]: greatsql.service: Start request repeated too quickly.
Jan 10 16:00:06 gip systemd[1]: greatsql.service: Failed with result 'exit-code'.
Jan 10 16:00:06 gip systemd[1]: Failed to start greatsql.service.
Jan 10 16:00:23 gip systemd[1]: /usr/lib/systemd/system/greatsql.service:1: Missing '='.

通過查看上述信息,可以得知 程序啟動的時候拋出了報錯。

 Main PID: 147226 (code=exited, status=203/EXEC)

通過上網搜索可以得知,status=203/EXEC 報錯可能和權限不足有關,記一下這里的PID。

我們繼續查看一下相關日志證實一下。

[root@Linux ~]# journalctl _PID=13386

-- Logs begin at Tue 2023-01-10 16:54:11 CST, end at Tue 2023-01-10 17:09:15 CST. --
Jan 10 17:00:36 gip systemd[13386]: greatsqld.service: Failed to execute command: Permission denied
Jan 10 17:00:36 gip systemd[13386]: greatsqld.service: Failed at step EXEC spawning /usr/local/greatsql/bin/mysqld: Permission denied

可以看到確實是權限不足。

但是奇怪的事情來了,通過查看文件權限發現權限并沒有問題。

[root@GreatSQL bin]# ls -lah |grep mysql
-rwxr-xr-x. 1 root root 6.9M 429 2022 mysql
-rwxr-xr-x. 1 root root 6.8M 429 2022 mysqladmin
-rwxr-xr-x. 1 root root 7.1M 429 2022 mysqlbinlog
-rwxr-xr-x. 1 root root 6.8M 429 2022 mysqlcheck
-rwxr-xr-x. 1 root root 6.3K 429 2022 mysqld_pre_systemd
-rwxr-xr-x. 1 root root 34K 429 2022 mysqld_safe
-rwxr-xr-x. 1 root root 6.9M 429 2022 mysqldump
-rwxr-xr-x. 1 root root 1.7K 429 2022 mysqldumpslow
***后省略***

即便把權限改成755,甚至777 也還是會報一樣的錯誤。

chown -R mysql:mysql /usr/local/mysql
chmod 755 -R /usr/local/mysql

問題原因

后面我有檢查了所有相關文件的權限,都沒問題,但是程序還是會報權限不足。

在網上翻閱了資料,發現了問題產生原因。

是SELinux 的問題, 因為我的二進制文件是先下載到 /root? 目錄,然后才移到 /usr/local/greatsql?目錄,從/root?目錄移動到/usr/local/目錄時它們的 SELinux 上下文不會自動變更,依然是用戶主目錄。所以出現了權限問題。

解決方法:

#恢復文件的安全上下文
restorecon -rv /usr/local/greatsql

總結

可執行文件是先存放在用戶目錄,然后移動到別的目錄,文件的 SELinux 上下文不會自動變更,依然是用戶目錄。

這就導致了,能直接運行,但是通過 systemd 啟動時仍然報 Permission denied權限不足的問題。

解決方法就是用restorecon命令用來恢復SELinux文件屬性

restorecon -rv 目標目錄

相關鏈接:

解決文件權限正確,但 systemd 服務仍然提示沒有權限,啟動失敗。(https://blog.csdn.net/kunyus/article/details/106592236)

一文帶你看懂 SELinux 是什么?  (redhat.com(https://www.redhat.com/zh/topics/linux/what-is-selinux)

責任編輯:武曉燕 來源: GreatSQL社區
相關推薦

2012-11-14 14:39:21

2013-05-10 10:39:15

2012-05-17 15:15:11

Linux

2022-12-08 15:29:59

開發應用應用申請權限

2012-09-05 11:09:15

SELinux操作系統

2011-10-10 10:17:16

2019-10-16 16:31:59

權限Android程序

2013-05-06 16:36:55

SELinuxSELinux故障

2011-05-31 14:22:23

2022-08-08 08:31:55

Go 語言閉包匿名函數

2022-08-08 06:50:06

Go語言閉包

2022-07-29 11:19:38

日志框架實踐

2019-07-25 15:10:11

攜號轉網業務運營商

2018-04-18 09:18:44

數據庫MySQL存儲過程

2022-12-13 10:05:13

MySQL數據庫

2016-11-07 09:20:24

2017-07-05 14:14:33

MySQL表服務變慢

2014-03-26 11:15:26

Hive

2020-06-11 14:33:10

MacBookLinux軟件

2024-09-26 10:44:53

MySQL數據庫數據
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲一区二区三区视频 | 亚洲精品1区 | 性视频网| 亚洲国产精品久久久久婷婷老年 | 一级做a爰片性色毛片16美国 | 成人超碰在线 | 欧美亚洲国语精品一区二区 | 国产精品一区二区av | 免费看一区二区三区 | 亚洲深夜福利 | 亚洲精品久久久久久久久久久久久 | 一级a性色生活片久久毛片 午夜精品在线观看 | 精品99久久久久久 | 日韩一级免费电影 | 亚洲a一区二区 | 神马久久春色视频 | 欧美一区二区视频 | 久草在线在线精品观看 | 精品国产一区二区在线 | av中文字幕在线 | 91亚洲精品国偷拍自产在线观看 | 在线日韩av电影 | 国产一区二区三区四区五区加勒比 | 欧美色综合一区二区三区 | 日本三级电影在线观看视频 | 狠狠操av | 日韩一二三区视频 | 国产精品久久久久久 | 欧美一区二区三区在线观看视频 | 91免费在线 | 中文字幕丁香5月 | 欧美日韩中文在线观看 | 午夜爱爱毛片xxxx视频免费看 | 中文字幕国产在线 | 毛片毛片毛片毛片毛片 | 国产精品久久久久久久久免费樱桃 | 欧美网站一区二区 | 香蕉婷婷 | 欧美视频在线播放 | 欧美精品乱码久久久久久按摩 | av在线视 |