用service命令管理mysql启停
来源:SegmentFault
时间:2023-02-23 16:30:24 209浏览 收藏
IT行业相对于一般传统行业,发展更新速度更快,一旦停止了学习,很快就会被行业所淘汰。所以我们需要踏踏实实的不断学习,精进自己的技术,尤其是初学者。今天golang学习网给大家整理了《用service命令管理mysql启停》,聊聊MySQL、日志、pid、linux运维、service,我们一起来看看吧!
安装完成
mysql之后,每次启动和停止都很麻烦,有时候记不住去网上搜一下,看见大家都用
service来进行服务的管理,试了一下,果然好用。推荐大家也要这么用,如果你的服务器版本高于
centos7,可以使用
systemd命令(取代
service命令)来管理。
启动和停止mysql
服务
# 启动 /usr/local/mysql/bin/mysqld --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --plugin-dir=/usr/local/mysql/lib/plugin --log-error=/var/log/mysqld.log --pid-file=/var/run/mysqld/mysqld.pid --socket=/tmp/mysql.sock # 停止 kill `cat /usr/local/mysql/var/mysqld.pid`
这样启动和停止需要记住
mysql的路径和
pid的保存位置,因此比较麻烦。
service
系统服务管理
service命令用于管理系统服务,比如启动
(start),停止
(stop),重启
(restart),查看状态
(status)等。
service命令本身就是一个
shell脚本,用于方便的调用该脚本来完成任务,它在
/etc/init.d/目录下查找指定的服务脚本。
相关的命令还有:
-
chkconfig:
用于查看、设置服务的运行级别 -
ntsysv:
用于设置服务的自启动
service运行指定服务(称为
System V初始脚本),只保留
LANG和
TERM两个环境变量,并设置当前路径为
/。如果一个服务脚本想要由
service进行管理,至少需要支持
start和
stop命令,并将脚本保存在
/etc/init.d/目录下。
service
的使用方式
## 命令格式 Usage: service | --status-all | [ service_name [ command | --full-restart ] ] # 查看指定服务的命令行使用帮助 service## mysqld 举例 $ service mysqld Usage: mysqld {start|stop|restart|reload|force-reload|status} [ MySQL server options ] # 启动、停止、重启指定服务 service start|stop|restart ## mysqld举例restart,即先执行stop再执行start命令 $ service mysqld restart Shutting down MySQL.. [ OK ] Starting MySQL. [ OK ] # 显示指定服务的状态 $ service mysqld status MySQL running (27390) [ OK ] # 显示所有服务的状态 service --status-all # 查看系统服务列表,以及每个服务的运行级别 chkconfig --list # 设置指定服务开机时是否自动启动 chkconfig on|off # 以全屏幕文本界面设置服务开机时是否自动启动 # 必须以root启动,空格切换状态,tab切换按钮,上下鼠标移动光标 ntsysv
除了用
mysqld示例外,我们修改了主机名、
IP地址等信息时,也要经常重启网络生效,此时可以调用:
service network status|restart
用service
管理mysqld
服务
我们已经了解了基础的知识,现在就可以开始改造了,首先要在你的安装目录里找到
mysql.server文件。
$ locate mysql.server /usr/local/mysql/support-files/mysql.server
这个文件在安装时初始化,其实也就是一个脚本文件,支持输入不同的参数执行不同的功能,我们可以查看它的
start函数:
# 根据输入的命令执行不同的脚本,首先判断是否为start case "$mode" in 'start') # Start daemon # Safeguard (relative paths, core dumps..) cd $basedir echo $echo_n "Starting MySQL" # 查看该bin/mysqld_safe命令是否存在,如果不存在,就直接报错:找不到 if test -x $bindir/mysqld_safe then # Give extra arguments to mysqld with the my.cnf file. This script # may be overwritten at next upgrade. # 直接执行mysqld_safe命令,并传入参数,然后创建pid文件 $bindir/mysqld_safe --datadir="$datadir" --pid-file="$mysqld_pid_file_path" $other_args >/dev/null & wait_for_pid created "$!" "$mysqld_pid_file_path"; return_value=$? # Make lock for RedHat / SuSE if test -w "$lockdir" then touch "$lock_file_path" fi exit $return_value else log_failure_msg "Couldn't find MySQL server ($bindir/mysqld_safe)" fi ;; 'stop')
然后将它复制到
/etc/init.d/目录下:
cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld
此时,就可以直接调用
service来进行启动了:
service mysqld start
遇到的一些问题
上面的理论很简单,但在启动的过程中还是遇到了一些问题,解决问题最简单的方法就是
配置文件被忽略
直接看启动时的报错信息:
$ service mysqld start Warning: World-writable config file '/etc/my.cnf' is ignored Starting MySQL.Warning: World-writable config file '/etc/my.cnf' is ignored
直接看报错原因,提示的是全局可写的配置文件被忽略。这个错误是指该配置文件可以被所有用户修改,因此有被恶意篡改的可能,因此不会引入这个文件的配置,忽略。
解决方案就是将该文件改为用户和用户组可读写,其他用户只读不可写:
chmod 664 /etc/my.cnf
PID
文件无法创建
直接看报错信息:
$ service mysqld start Starting MySQL.The server quit without updating PID file (/usr/var/mysql/var/mysqld.pid).
报错原因显示,启动
MySQL时意外退出,因为没有更新
PID文件。
这个时候,可能有些人看不太懂,没关系,我们直接看错误日志:
2019-03-21 22:29:45 32896 [ERROR] /usr/local/mysql/bin/mysqld: Can't create/write to file '/usr/var/mysql/var/mysqld.pid' (Errcode: 2 - No such file or directory) 2019-03-21 22:29:45 32896 [ERROR] Can't start server: can't create PID file: No such file or directory
这个日志就很清楚的写明了无法创建这个
mysqld.pid文件,要么是权限问题,要么是路径不存在的问题,后面看发现是路径写错了,更改为正确的路径即可。
有时这个错误的信息指示并不明确,你可以尝试通过
chmod 777 -R /path/to/mysql/data解决问题。
错误日志路径的设置:
$ vim my.cnf [mysqld] basedir = /usr/local/mysql datadir = /usr/local/mysql/data pid-file = /usr/var/mysql/var/mysqld.pid log-error = /user/local/mysql/log/mysql.err
log
指令被废弃
解决了上面的问题,我们继续执行,依然发现同样的报错信息,但是日志文件却不同了:
$ service mysqld start Starting MySQL.The server quit without updating PID file (/usr/var/mysql/var/mysqld.pid). # 日志文件 2019-03-21 22:37:33 0 [ERROR] /usr/local/mysql/bin/mysqld: ambiguous option '--log=/usr/local/mysql/log/mysql.log' (log-bin, log_slave_updates) 2019-03-21 22:37:33 0 [ERROR] Aborting
发现日志报错信息提示:模糊的选项
--log,这个不太明白,
--log指令已经被废弃很久了,现在使用
--general-log来代替。修改
my.cnf配置文件即可:
$ vim my.cnf [mysqld] general-log = /user/local/mysql/log/mysql.log
default-character-set
指令被废弃
继续执行,依然同样的报错信息,查看日志文件:
2019-03-22 16:17:36 10893 [Note] InnoDB: 5.6.39 started; log sequence number 6572813439 2019-03-22 16:17:36 10893 [ERROR] /usr/local/mysql/bin/mysqld: unknown variable 'default-character-set=utf8' 2019-03-22 16:17:36 10893 [ERROR] Aborting
报错提示
default-character-set未知指令,查看官方文档 Server Command Options发现,该指令从
5.5.3版本被废弃,用
character-set-server来取代了。而我们的版本是
5.6.39,因此替换掉该指令即可:
[mysqld] character-set-server=utf8
my_print_defaults
命令未找到
因为这个命令未找到,我们首先就是要找到这个命令的路径,然后将它添加到全局命令中:
$ locate my_print_defaults /home/work/lnmp/mysql/bin/my_print_defaults $ ln -s /home/work/lnmp/mysql/bin/my_print_defaults /usr/bin/
重新启动,该错误消失。
/usr/local/mysql: No such file or directory
未找到数据库目录
是因为该启动脚本默认数据库在
/usr/local目录进行安装,因此代码中有一段配置,改写即可:
$ vim /etc/init.d/mysqld # If you install MySQL on some other places than /usr/local/mysql, then you # have to do one of the following things for this script to work: # # - Run this script from within the MySQL installation directory # - Create a /etc/my.cnf file with the following information: # [mysqld] # basedir=# - Add the above to any other configuration file (for example ~/.my.ini) # and copy my_print_defaults to /usr/bin # - Add the path to the mysql-installation-directory to the basedir variable # below. # basedir=/home/work/mysql/ datadir=/home/work/mysql/data/
启动成功
解决了上面这些问题,终于可以成功启动了,这个时候我们可以方便的对
mysqld服务进行启停以及
restart了。
虽然
service支持
reload/force-reload参数,但是这个需要相关的服务支持才可以,然而
MySQL并不支持配置实时
reload,所以,还是需要你
restart才能立刻更新配置。
$ service mysqld start Starting MySQL. [ OK ]
centos7: systemd
命令
centos7版本中使用了systemd,systemd同时兼容service,对应的命令就是systemctl
Systemd 是 Linux 系统中最新的初始化系统(init),它主要的设计目标是克服 sysvinit 固有的缺点,提高系统的启动速度
使用systemd的目的是获取更快的启动速度。
但是由于我的服务器版本还是centos6,所以没有办法对这一部分做测试介绍,只能还是使用service命令来管理了。
总结
Service服务管理工具,可以帮助我们快速的启停应用程序。如果你的服务器版本在
centos7以上,可以使用
systemd来进行管理。同时在
Mysql启动的过程中,掌握日志文件的查看和
参考资料
- 我使用过的Linux命令之service - 系统服务管理:https://codingstandards.iteye...
- 安装mysql后设置为linux服务:https://blog.csdn.net/qq84545...
- service命令:http://man.linuxde.net/service
- MySQL无法重启问题解决Warning: World-writable config file ‘/etc/my.cnf’ is ignored:http://www.ttlsa.com/mysql/wa...
- my.cnf:https://devilbox.readthedocs....
- MySQL Error on Startup: ambiguous option '--log=/var/log/mysqld.log':https://serverfault.com/quest...
- init,service和systemctl的区别:https://blog.csdn.net/lineuma...
- 5.1.6 Server Command Options:https://dev.mysql.com/doc/ref...
- 10.14 Character Set Configuration:https://dev.mysql.com/doc/ref...
本篇关于《用service命令管理mysql启停》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于数据库的相关知识,请关注golang学习网公众号!
-
499 收藏
-
432 收藏
-
485 收藏
-
244 收藏
-
235 收藏
-
184 收藏
-
237 收藏
-
210 收藏
-
192 收藏
-
364 收藏
-
373 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习