zoukankan      html  css  js  c++  java
  • 基于linux使用mysql二进制包安装mysql5.5

    前言

    使用mysql也有一段时间,但是安装mysql,都是在linux上使用软件源的安装,再使用mysql自带的shell执行的便捷启动,对于mysql内部的启动参数不甚了解,所以特意从mysql官网下载mysql的tar包,自行安装启动,了解mysql程序的启动过程,有助于启动过程的排错,进一步了解mysql。

    环境

    ubuntu 12.04 32bit

    下载mysql

    1.下载:在http://dev.mysql.com/downloads/mysql/官网上下载mysql-5.5.28-linux2.6-i686.tar.gz.

    2.解压

    tar -xvf mysql-5.5.28-linux2.6-i686.tar.gz

    3.移动到/usr/local/mysql

    mv mysql-5.5.28-linux2.6-i686 /usr/local/
    ln -s mysql-5.5.28-linux2.6-i686/ mysql

    4.安装依赖的lib包:执行/usr/local/bin/mysql/bin/mysqld,报错

    /usr/local/mysql/bin/mysqld: error while loading shared libraries: libaio.so.1: cannot open shared object file: No such file or directory

    使用apt-cache search libaio,找到如下软件源

    libaio-dev - Linux kernel AIO access library - development files
    libaio1 - Linux kernel AIO access library - shared library
    libaio1-dbg - Linux kernel AIO access library - debugging symbols

    使用apt-get install libaio1.

    配置用户,目录

    shell> groupadd mysql
    shell> useradd -r -g mysql mysql
    shell> cd /usr/local/mysql
    shell> chown -R mysql .
    shell> chgrp -R mysql .

    初始化mysql

    shell> scripts/mysql_install_db --user=mysql
    # Next command is optional shell
    > cp support-files/my-medium.cnf /etc/my.cnf
    # Next command is optional
    shell> cp support-files/mysql.server /etc/init.d/mysql.server

     这里最重要的就是初始化mysql的一些权限账户表,默认创建了一个空密码的root用户

    启动mysql

    最简单的启动方式:

    shell> /usr/local/mysql/bin/mysqld --user=mysql

    默认情况下使用/usr/local/mysql/data作为mysql的数据目录,包括数据库文件,log日志。

    常用的mysql启动参数:

    /usr/local/mysql/bin/mysqld  --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data  --port=3306 --socket=/tmp/mysql.sock

    推荐的启动mysql

    /usr/local/mysql/support-files/mysql.server start

    一般来说,没什么特别需要的话就是使用上述脚本启动mysql服务器了,这个脚本可以加入到linux的系统服务。

    关闭mysql

    最简单的方式

    killall mysqld

    推荐的方式

    /usr/local/mysql/support-files/mysql.server stop

    使用mysql.server stop关闭mysqld会销毁pid文件,并做容错操作,但是最后也是调用kill命令kill mysql。

    关闭mysql,尽量不要用kill -9 mysql_pid或者是killall -9 mysql,否则mysql进程无法做退出处理,就可能会丢失数据,甚至导致表损坏。

    浅析mysql.server脚本的启动流程

    mysql.server脚本可以看到在以下脚本调用mysqld_safe这个bash

    $bindir/mysqld_safe --datadir="$datadir" --pid-file="$mysqld_pid_file_path" $other_args >/dev/null 2>&1 &

    默认情况下,$bindir/mysqld_safe就是/usr/local/mysql/bin/mysqld_safe这个shell,我的本机的调用参数如下:

    /bin/sh /usr/local/mysql/bin/mysqld_safe --datadir=/usr/local/mysql/data --pid-file=/usr/local/mysql/data/blue-pc.pid

    而mysqld_safe也是一个shell,可以看到在这个脚本在初始化N多变量后,调用

    eval_log_error "$cmd"

    这个shell function最后就是调用

     #echo "Running mysqld: [$cmd]"
     eval "$cmd"

    在我本机,这个$cmd就是

    /usr/local/mysql/bin/mysqld --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --plugin-dir=/usr/local/mysql/lib/plugin --user=mysql --log-error=/usr/local/mysql/data/blue-pc.err --pid-file=/usr/local/mysql/data/blue-pc.pid

    参考 http://dev.mysql.com/doc/refman/5.5/en/binary-installation.html

  • 相关阅读:
    Charles抓包工具
    JQuery 实现表单验证,所有验证通过方可提交
    卡巴斯基注册信息清除
    Nginx 404 Not Found 解决办法
    php mysql 多表查询之子查询语句
    搜狗拼音、QQ拼音输入法、2345拼音输入法、百度输入法 、手心输入法对比。(个人体会)
    Notepad++使用-如何导出/导入配置文件
    深蓝词库转换2.4版发布,支持最新的搜狗用户词库备份bin格式
    网站更换服务器,百度站长后台抓取诊断时间
    阿里云代金券领取
  • 原文地址:https://www.cnblogs.com/mazefeng/p/3359810.html
Copyright © 2011-2022 走看看