av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術(shù)文章
文章詳情頁

詳解MySQL中的pid與socket

瀏覽:131日期:2023-10-01 18:04:53
目錄1.pid-file介紹2.socket文件介紹總結(jié): socket文件:當(dāng)用Unix域套接字方式進(jìn)行連接時需要的文件。 pid文件:MySQL實(shí)例的進(jìn)程ID文件。1.pid-file介紹

MySQL 中的 pid 文件記錄的是當(dāng)前 mysqld 進(jìn)程的 pid ,pid 亦即 Process ID 。可以通過 pid-file 參數(shù)來配置 pid 文件路徑及文件名,如果未指定此變量,則 pid 文件默認(rèn)名為 host_name.pid ,存放的路徑默認(rèn)放在 MySQL 的數(shù)據(jù)目錄。

建議指定 pid 文件名及路徑,pid 目錄權(quán)限要對 mysql 系統(tǒng)用戶放開,具體配置可參考如下:

# my.cnf 配置文件[mysqld]pid-file = /data/mysql/tmp/mysqld.pid# 查看mysqld進(jìn)程[root@localhost ~]# ps -ef|grep mysqldroot 8670 1 0 Jun09 ?00:00:00 /bin/sh /usr/local/mysql/bin/mysqld_safe --datadir=/data/mysql/data --pid-file=/data/mysql/tmp/mysqld.pidmysql 9353 8670 0 Jun09 ?00:01:23 /usr/local/mysql/bin/mysqld --basedir=/usr/local/mysql --datadir=/data/mysql/data --plugin-dir=/usr/local/mysql/lib/plugin --user=mysql --log-error=/data/mysql/logs/error.log --pid-file=/data/mysql/tmp/mysqld.pid --socket=/data/mysql/tmp/mysql.sock# 查看pid文件內(nèi)容 [root@localhost ~]# cat /data/mysql/tmp/mysqld.pid9353

可以看到 pid 文件內(nèi)容只有一行,記錄了 mysqld 進(jìn)程的 ID 。mysqld 進(jìn)程啟動后會通過 create_pid_file 函數(shù)新建 pid 文件,通過 getpid() 獲取當(dāng)前進(jìn)程號并將進(jìn)程 ID 寫入 pid 文件。進(jìn)程運(yùn)行后會給 pid 文件加一個文件鎖,只有獲得 pid 文件寫入權(quán)限的進(jìn)程才能正常啟動并把自身的 PID 寫入該文件中,其它同一個程序的多余進(jìn)程則自動退出。因此 pid 文件的作用是防止啟動多個進(jìn)程副本。

有時候可能會遇到因 pid 文件問題而啟動失敗的情況,這幾類報錯你可能遇到過:

Can‘t start server: can‘t create PID file: No such file or directory

ERROR! MySQL server PID file could not be found

ERROR! The server quit without updating PID file

上面幾類 pid 相關(guān)報錯解決方法其實(shí)都是類似的,首先要看下 error log 找到具體報錯,然后查看配置文件,確保 pid 文件目錄路徑正確且有權(quán)限有空間,之后可以看下 mysqld 進(jìn)程是否存在,若存在可手動 kill 掉,若有殘留的 pid 文件也可以先刪掉,一切排查就緒后,再次重新啟動,一般即可成功。

2.socket文件介紹

socket 即 Unix 套接字文件,在類 unix 平臺,客戶端連接 MySQL 服務(wù)端的方式有兩種,分別是 TCP/IP 方式與 socket 套接字文件方式。Unix 套接字文件連接的速度比 TCP/IP 快,但是只能連接到同一臺計算機(jī)上的服務(wù)器使用。

通過設(shè)置 socket 變量可配置套接字文件路徑及名稱,默認(rèn)值為 /tmp/mysql.sock (對于某些發(fā)行格式,目錄可能有所不同)。參考配置如下:

# my.cnf 配置文件[mysqld]socket = /data/mysql/tmp/mysql.sock[client]socket = /data/mysql/tmp/mysql.sock# 查看對應(yīng)目錄下的socket文件root@localhost tmp]# ls -lhtotal 8.0Ksrwxrwxrwx 1 mysql mysql 0 Jun 10 15:19 mysql.sock-rw------- 1 mysql mysql 6 Jun 10 15:19 mysql.sock.lock# 通過 -S 命令指定socket登錄[root@localhost ~]# mysql -uroot -pxxxx -S /data/mysql/tmp/mysql.sockmysql: [Warning] Using a password on the command line interface can be insecure.Welcome to the MySQL monitor. Commands end with ; or g.Your MySQL connection id is 12Server version: 8.0.22 MySQL Community Server - GPLCopyright (c) 2000, 2020, Oracle and/or its affiliates. All rights reserved.Oracle is a registered trademark of Oracle Corporation and/or itsaffiliates. Other names may be trademarks of their respectiveowners.Type ’help;’ or ’h’ for help. Type ’c’ to clear the current input statement.mysql> status--------------mysql Ver 8.0.22 for Linux on x86_64 (MySQL Community Server - GPL)Connection id: 12Current database:Current user: root@localhostSSL: Not in useCurrent pager: stdoutUsing outfile: ’’Using delimiter:;Server version: 8.0.22 MySQL Community Server - GPLProtocol version: 10Connection: Localhost via UNIX socketServer characterset: utf8mb4Db characterset: utf8mb4Client characterset: utf8mb4Conn. characterset: utf8mb4UNIX socket: /data/mysql/tmp/mysql.sockBinary data as: HexadecimalUptime: 1 hour 27 min 31 secThreads: 3 Questions: 27 Slow queries: 0 Opens: 135 Flush tables: 3 Open tables: 56 Queries per second avg: 0.005

查看上述連接狀態(tài)可知,MySQL 在本地可以通過 socket 方式連接。在本地登錄時,如果 my.cnf 配置文件中的 [client] 部分沒有指定 socket 文件路徑,mysql 默認(rèn)會去尋找 /tmp/mysql.sock ,所以如果 mysqld 服務(wù)啟動的時候,生成的 socket 文件不是默認(rèn)路徑的話,登陸可能會報錯(ERROR 2002 (HY000): Can’t connect to local MySQL server through socket ’/tmp/mysql.sock’)。其實(shí) [mysqld] 部分及 [client] 部分都配置具體路徑可避免此問題,也可以在 tmp 路徑下建立軟連接,如:ln -s /data/mysql/tmp/mysql.sock /tmp/mysql.sock 。同樣的,socket 文件目錄權(quán)限要對 mysql 系統(tǒng)用戶放開。

總結(jié):

本篇文章介紹了 MySQL 中的 pid 及 socket 文件的具體配置及作用。其實(shí)這兩個參數(shù)還是比較好維護(hù)的,一開始配置好不要去動它就好了,若遇到重啟報錯的情況,根據(jù)錯誤日志慢慢來排查,細(xì)心的操作,總會找到問題的。

以上就是詳解MySQL中的pid與socket的詳細(xì)內(nèi)容,更多關(guān)于MySQL pid與socket的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: MySQL 數(shù)據(jù)庫
相關(guān)文章:
主站蜘蛛池模板: 国产一区不卡 | 国产色 | 瑟瑟视频在线看 | 欧美不卡一区二区三区 | 精品久久久久久久久久 | 国产色播av在线 | 国产91在线播放 | 一区二区免费 | 国产色播av在线 | 一区二区三区亚洲精品国 | 国产中文字幕在线观看 | 成人一区二区三区在线观看 | 亚洲一区二区在线播放 | 久久国产精品一区 | 日本网站免费观看 | 亚洲激情专区 | 成人三区四区 | 免费黄色片在线观看 | 亚洲精品成人av久久 | 五月天婷婷久久 | 永久免费在线观看 | 粉嫩一区二区三区四区公司1 | 欧美一区二区三区在线视频 | 人人做人人澡人人爽欧美 | 精品欧美乱码久久久久久1区2区 | 日韩精品视频一区二区三区 | 国产丝袜人妖cd露出 | 国产精品久久久久久久久久久久午夜片 | 色欧美片视频在线观看 | www.日韩av.com | 色综合一区二区 | 免费a国产 | 欧美日韩1区2区3区 欧美久久一区 | 日韩精品一区二区三区视频播放 | 狠狠躁天天躁夜夜躁婷婷老牛影视 | 国产精华一区 | www.婷婷| 国产区在线观看 | 伊人免费视频二 | 成人欧美一区二区三区黑人孕妇 | 国产精品夜夜春夜夜爽久久电影 |