对MySQL数据库正式安装的详细说明

我们大家都知道在安装MySQL数据库好之后,我们就可以对其进行正式的安装了。我们以假设的方式来对其实际操作步骤进行说明的,假设把所有必须的源码或包都放在了/tmp之下下。如果你下载的是RPM包的话,那比较简单;

如果你下载的是二进制包(你没有rpm程序或者你想自定义的话),那么会稍微麻烦一点。

RPM包安装

你必须成为root用户才能使用rpm安装程序,以下是安装过程:

 

  1. $ cd /tmp  
  2. $ su  
  3. # rpm -Uvh MySQL*(安装和MySQL相关的所有包) 

这将安装你下载的所有3个MySQL包。如果你的系统是RedHat Linux的话,建议使用RPM安装方式,因为所有的工作都由rpm程序帮你搞好了。

源码安装

相对于用RPM安装来讲,用二进制源码安装是稍微麻烦了点。但是我们可以在安装脚本中可以自定义安装的相关参数,而不用象rpm方式只能安装默认的来安装。

安装二进制源代码

如果你下载的是二进制源代码,它的名字类似于: 安装MySQL-3.22.21-pc-linux-gnu-i686.tar.gz。你必须成为root用户,然后解压到 /usr/local目录,操作步骤如下:

 

  1. $ cd /usr/local  
  2. $ su  
  3. # tar -zxvf /tmp/MySQL-3.22.21-pc-linux-gnu-i686.tar.gz 

在所有文件解压完后,一个名字叫MySQL-3.22.21-pc-linux-gnu-i686的目录将被创建出来。我们为这个目录做个符号链接,并给它一个更友好的名字MySQL (免得叫MySQL-3.22.21-pc-linux-gnu-i686这么长):

 

  1. # ln -s MySQL-3.22.21-pc-linux-gnu-i686 MySQL 

如果以后有新版本的MySQL的话,你可以仅仅将源码解压到新的路径,然后只需要做个符号链接就可以了。这样非常方便,数据也更加安全。

建立一个MySQL 用户

好,现在我们将建立一个能运行MySQL守护程序的用户帐号,并且所有MySQL文件都归此帐户拥有。使用 Linuxconf或者useradd命令去添加一个叫 MySQL 的帐号,在添加之前,确保没有人注册了这个帐户,还要暂时禁止login功能(不过一般都是在没有其他人登陆的情况下调试机器,因此这个步骤可免)

为MySQL做准备

首先让我们将MySQL目录和文件的拥有权改成 安装MySQL 用户和root组:

 

  1. # cd /usr/local  
  2. # chown -R MySQL:root MySQL-3.22.21-pc-linux-gnu-i686 MySQL 

然后运行一个小脚本程序,以建立初始化的MySQL数据库。请以一个MySQL 用户的身份完成这个任务,这也是我们能够直接使用这个帐户的唯一机会。

 

  1. # su MySQL  
  2. $ cd MySQL  
  3. $ scripts/MySQL_install_db  
  4. $ exit 

如果没有任何出错信息显示的话,那就可以了。

自动运行MySQL

在MySQL二进制包里面,有一个叫myslq.server的启动脚本程序。把它复制到/etc/rc.d/init.d目录里面:

 

  1. # cd /etc/rc.d/init.d  
  2. # cp /usr/local/mysql/support-files/mysql.server mysql 

接着把它的属性改为“x”(executable,可执行)

 

  1. # chmod +x mysql 

***,运行chkconfig把MySQL添加到你系统的启动服务组里面去。

 

  1. # /sbin/chkconfig --del mysql  
  2. # /sbin/chkconfig --add mysql 

测试MySQL

安装MySQL里面有一个简单的数据库例子test ,而且它的内部数据库一直保持对权限和帐户的监视,因而先运行mysql看看是否可以工作。

首先启动MySQL:

 

  1. # /etc/rc.d/init.d/mysql start 

如果一切正常,你将看到以下的信息出现:

 

  1. Starting mysqld daemon with databases from /var/lib/mysql 

如果你安装的是RPM包,那么程序大都安装在/usr/local/mysql/bin。在此目录下运行客户端程序:

 

  1. # mysql 

然后你可以看到屏幕显示出以下信息:

 

  1. Welcome to the MySQL monitor. Commands end with ; or \g.  
  2. Your MySQL connection id is 2 to server version: 3.22.21  
  3. Type 'help' for help.  
  4. mysql> 

 

接着,用show databases命令可以将安装的数据库列出来:

 

  1. mysql> show databases; 

你就可以看到:

 

  1. +----------+  
  2. | Database |  
  3. +----------+  
  4. | mysql |  
  5. | test |  
  6. +----------+  
  7. 2 rows in set (0.00 sec)  

 

如果一切正常的话,那说明MySQL可以完全工作了!恭喜你!如果要退出程序,输入:exit

 

  1. mysql> exit;  
  2. Bye  

 

更改管理员密码

在一切正常后,要做的***件事情是更改管理员的密码。你可以运行安装mysqladmin (请注意,此命令不一定在你的path中,所以***是转到此命令的目录中直接执行):

 

  1. # mysqladmin -u root password newpassword 

此命令把root用户的口令变成newpassword。当然你可以把口令换成其它,因为这个很容易破解。

【编辑推荐】

  1. MySQL连接字符串中的几个重要步骤
  2. 安装MySQL在linux as3之下
  3. MySQL配置SSL的实际操作流程
  4. MySQL忘记密码的正确解决方法
  5. MySQL 基本命令的用法与注意事项

文章来源网络,作者:管理,如若转载,请注明出处:https://shuyeidc.com/wp/226572.html<

(0)
管理的头像管理
上一篇2025-04-17 10:34
下一篇 2025-04-17 10:35

相关推荐

  • 云服务器和云虚拟主机怎么选?云服务器和虚拟主机区别

    云服务器适合业务增长快、需弹性扩展的场景,而云虚拟主机适合预算有限、技术门槛低的小型静态网站或测试环境,二者核心区别在于资源独享性与运维复杂度,核心差异解析:从底层架构到使用体验很多人容易混淆这两者,觉得它们都是“买空间建站”,它们的底层逻辑完全不同,云服务器(ECS)就像是你租了一整栋别墅,水电网络独立,你想……

    2026-06-29
    0
  • 赣州智慧旅游招聘是真的吗?赣州旅游人才招聘信息

    中级岗位(3-5年经验)月薪范围通常在6000-10000元,这类岗位需要独立负责项目模块,如独立运营一个抖音账号,或维护一个景区小程序的功能迭代,具备成功案例的候选人议价能力较强,高级岗位(5年以上经验)月薪范围通常在10000-20000元,部分核心管理岗可达更高,这类人才需要具备战略规划能力,如制定整个景……

    2026-06-29
    0
  • 赣州智能物联网车位锁如何管理?智能车位锁管理系统多少钱

    赣州智能物联网车位锁管理的核心在于通过云端平台实现远程控锁、状态实时监控及自动计费,彻底解决传统车位“被占难管”与“找位难”的痛点,在赣州这样的城市,随着机动车保有量的持续增长,老旧小区、商业综合体以及私人固定车位的资源矛盾日益凸显,传统的机械地锁或简易遥控锁,不仅操作繁琐,更无法实现数据化管理,引入智能物联网……

    2026-06-29
    0
  • 赣州智能消防栓好用吗,智能消防栓多少钱一个

    赣州智能消防栓通过物联网技术实现实时监测与远程报警,能显著降低火灾响应时间并提升城市消防安全管理水平,是目前智慧城市建设中不可或缺的基础设施,赣州智能消防栓的核心价值与应用场景传统消防栓往往存在“看不见、摸不着、用不了”的痛点,在赣州这样地形复杂、老城区与新城区并存的区域,传统设施的管理难度极大,智能消防栓的出……

    2026-06-29
    0
  • 云服务器和物理机到底有啥区别?

    云服务器本质上是虚拟化资源池中的弹性实例,而传统物理服务器是独占的硬件实体,前者胜在弹性与运维便捷,后者强在物理隔离与性能稳定,具体选择取决于业务对成本、扩展性及安全合规的权衡,很多人初次接触服务器时,容易把“云服务器”和“传统物理服务器”混为一谈,觉得它们都是用来跑网站或存数据的盒子,这两者的底层逻辑完全不同……

    2026-06-29
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注