我的编程空间,编程开发者的网络收藏夹
学习永远不晚

使用service命令该如何管理mysql启动和停止

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

使用service命令该如何管理mysql启动和停止

下文主要给大家带来使用service命令该如何管理mysql启动和停止,希望这些内容能够带给大家实际用处,这也是我编辑使用service命令该如何管理mysql启动和停止这篇文章的主要目的。好了,废话不多说,大家直接看下文吧。                                                             

启动和停止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 < option > | --status-all | [ service_name [ command | --full-restart ] ]

# 查看指定服务的命令行使用帮助
service <service>
## mysqld 举例
$ service mysqld
Usage: mysqld  {start|stop|restart|reload|force-reload|status}  [ MySQL server options ]

# 启动、停止、重启指定服务
service <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 <service> 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')

然后将它复制到/tmp/init.d/目录下:

cp /usr/local/mysql/support-files/mysql.server /tmp/init.d/mysqld

此时,就可以直接调用service来进行启动了:

service mysqld start

遇到的一些问题

上面的理论很简单,但在启动的过程中还是遇到了一些问题,解决问题最简单的方法就是Google+查看日志文件,这两个方法可以非常快的速度定位并解决。

配置文件被忽略

直接看启动时的报错信息:

$ 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文件,要么是权限问题,要么是路径不存在的问题,后面看发现是路径写错了,更改为正确的路径即可。

错误日志路径的设置:

$ 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,这个不太明白,Google一下就能看到原因:--log指令已经被废弃很久了,现在使用--general-log来代替。修改my.cnf配置文件即可:

$ vim my.cnf
[mysqld]
general-log = /user/local/mysql/log/mysql.log

启动成功

解决了上面这些问题,终于可以成功启动了,这个时候我们可以方便的对mysqld服务进行启停以及reload了:

$ service mysqld start
Starting MySQL.                                            [  OK  ]

对于以上关于使用service命令该如何管理mysql启动和停止,大家是不是觉得非常有帮助。如果需要了解更多内容,请继续关注我们的行业资讯,相信你会喜欢上这些内容的。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

使用service命令该如何管理mysql启动和停止

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何使用批处理实现启动和停止服务

这篇文章给大家分享的是有关如何使用批处理实现启动和停止服务的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。使用windows自带的net.exe功能启动或停止服务 启动/停止 服务的命令行格式为: net star
2023-06-08

如何使用windows bat脚本命令一键启动MySQL服务

这篇文章主要介绍如何使用windows bat脚本命令一键启动MySQL服务,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!@echo offrem Copyright (c) 2019 Moses and/or it
2023-06-08

LINUX如何利用远程管理命令进行关机和重启

这篇“LINUX如何利用远程管理命令进行关机和重启”除了程序员外大部分人都不太理解,今天小编为了让大家更加理解“LINUX如何利用远程管理命令进行关机和重启”,给大家总结了以下内容,具有一定借鉴价值,内容详细步骤清晰,细节处理妥当,希望大家
2023-06-28

LINUX中如何利用远程管理命令进行关机和重启

这篇文章给大家分享的是有关LINUX中如何利用远程管理命令进行关机和重启的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。方法如下1、打开LINUX,这里用UBUNTU操作系统,打开左边的终端窗口。2、直接输入shu
2023-06-13

如何实现CMD命令行中以管理员权限启动应用程序

本篇内容主要讲解“如何实现CMD命令行中以管理员权限启动应用程序”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何实现CMD命令行中以管理员权限启动应用程序”吧!很多时候我们需要管理员权限来运行
2023-06-08

Linux系统如何使用rfkill命令来管理蓝牙和wifi

这篇文章主要介绍Linux系统如何使用rfkill命令来管理蓝牙和wifi,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!#列出所有可用设备rfkill list0: ideapad_wlan: Wireless LA
2023-06-28

如何使用Linux中的用户密码管理命令passwd和change

这篇文章主要介绍“如何使用Linux中的用户密码管理命令passwd和change”,在日常操作中,相信很多人在如何使用Linux中的用户密码管理命令passwd和change问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希
2023-06-12

如何利用MySQL和C++开发一个基于命令行的图书管理系统

如何利用MySQL和C++开发一个基于命令行的图书管理系统概要:在本文中,我们将介绍如何使用MySQL和C++开发一个简单的基于命令行的图书管理系统。我们将涵盖从数据库设计到C++代码实现的整个过程,并提供具体的代码示例。介绍:图书管理系统
2023-10-22

windows主机中如何使用批处理命令检查网卡网络自动重启网卡

这篇文章主要为大家展示了“windows主机中如何使用批处理命令检查网卡网络自动重启网卡”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“windows主机中如何使用批处理命令检查网卡网络自动重启网
2023-06-04

编程热搜

目录