Linux下MySQL免安装版的安装、配置及开机启动

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: Linux安装MySQL免安装版

1.查看并卸载预装MariaDB

由于CentOS7默认预装MariaDB,分别执行如下命令,将其卸载

#查看系统自带的mariadb
rpm -qa|grep mariadb
#卸载自带的mariadb
rpm -e --nodeps mariadb-libs-5.5.44-2.el7.centos.x86_64
#删除etc目录下的my.cnf
rm /etc/my.cnf

image.png

2.检查mysql是否存在

rpm -qa | grep mysql

3.查看和创建mysql用户和组

出于安全原因,在系统中创建一个mysql用户和用户组,依次执行如下命令,并设置好mysql用户的密码即可。

# 检查mysql组和用户是否存在,如无则创建
cat /etc/group | grep mysql 
cat /etc/passwd | grep mysql 
#创建mysql用户组
# 创建mysql用户组
groupadd mysql
# 创建一个用户名为mysql的用户,并加入mysql用户组
useradd -g mysql mysql
# 制定password 为111111,输入New password ,重复retype new password
passwd mysql

image.png

4.下载安装包并解压

前往mysql官网下载对应的Linux安装包mysql-5.7.31-linux-glibc2.12-x86_64.tar.gz,上传至服务器/home目录下,并执行如下命令,完成解压操作

cd /usr/local
# 解压缩
tar -zxvf /home/mysql-5.7.31-linux-glibc2.12-x86_64.tar.gz
# 文件夹重命名
mv mysql-5.7.31-linux-glibc2.12-x86_64 mysql

5.更改所属的组和用户

chown -R mysql mysql/
chgrp -R mysql mysql/
cd mysql/
mkdir data
chown -R mysql:mysql data

6.在/etc创建my.cnf文件

# 进入/etc文件夹下
cd /etc
# 创建my.cnf文件
touch my.cnf 
# 编辑my.cnf
vim my.cnf 

在my.cnf添加如下内容

[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8 

[mysqld]
# 设置3306端口
port = 3306 
# 设置mysql的安装目录
basedir=/usr/local/mysql
# 设置mysql数据库的数据的存放目录
datadir=/usr/local/mysql/data
# 允许最大连接数
max_connections=200
# 服务端使用的字符集默认为8比特编码的latin1字符集
character-set-server=utf8
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB 
lower_case_table_names=1
max_allowed_packet=16M
sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

可以通过cat /etc/my.cnf查看文档的内容

7.执行安装

# 进入mysql
cd /usr/local/mysql/ 
# 安装mysql
bin/mysql_install_db --user=mysql --basedir=/usr/local/mysql/ --datadir=/usr/local/mysql/data/

image.png

如果出现如下提示:
error while loading shared libraries: libaio.so.1: cannot open shared object file: No such file or directory
解决办法:执行如下命令安装对应软件包即可
yum install -y libaio //安装后在初始化就OK了

安装mysql出现了3个warning信息。修改系统的max_open_files限制即可
解决办法:编辑/etc/security/limits.conf ,最后面增加两行
* hard nofile 65535
* soft nofile 65535

8.编写启动脚本

cp ./support-files/mysql.server /etc/init.d/mysqld
chown 777 /etc/my.cnf 
chmod +x /etc/init.d/mysqld

9.启动mysql

/etc/init.d/mysqld restart

image.png

如果出现错误提示:MySQL manager or server PID file could not be found! [FAILED]
解决办法:杀死相关进程,重启mysql
# 1、查看进程
ps aux|grep mysql
# 2、杀死进程(以实际查询出来的进程号为准)
kill -9 10031
kill -9 10220
# 3、重启mysql
/etc/init.d/mysqld restart

10.设置开机启动

chkconfig --level 35 mysqld on
chkconfig --list mysqld
chmod +x /etc/rc.d/init.d/mysqld
chkconfig --add mysqld
chkconfig --list mysqld
service mysqld status

image.png

11.修改配置文件

vim /etc/profile

添加如下内容

#SET MYSQL ENVIRONMENT
export PATH=$PATH:/usr/local/mysql/bin

image.png

使配置文件生效

source /etc/profile

12.获取mysql初始密码

cat /root/.mysql_secret

image.png

13.修改密码

mysql -uroot -p
set PASSWORD = PASSWORD('root');
flush privileges;

image.png

14.添加远程访问权限

use mysql;
select host,user,authentication_string from mysql.user;
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root' WITH GRANT OPTION;
FLUSH PRIVILEGES;

create user 'test'@'localhost' identified by 'Test_2020!@#';
create user 'test'@'%' identified by 'Test_2020!@#';
GRANT ALL PRIVILEGES ON *.* TO 'test'@'%' IDENTIFIED BY 'Test_2020!@#' WITH GRANT OPTION;
GRANT ALL PRIVILEGES ON *.* TO 'test'@'localhost' IDENTIFIED BY 'Test_2020!@#' WITH GRANT OPTION;
FLUSH PRIVILEGES;

image.png

15.重启mysql

/etc/init.d/mysqld restart 

image.png

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
18天前
|
弹性计算 关系型数据库 MySQL
centos7 mysql安装及配置
本文详细介绍了在阿里云服务器ECS上通过yum源安装MySQL 8.0.12的过程,包括更新yum源、下载并安装MySQL源、解决安装过程中可能遇到的问题等步骤。此外,还介绍了如何启动MySQL服务、设置开机自启、配置登录密码、添加远程登录用户以及处理远程连接异常等问题。适合初学者参考,帮助快速搭建MySQL环境。
95 8
centos7 mysql安装及配置
|
14天前
|
NoSQL 关系型数据库 Redis
mall在linux环境下的部署(基于Docker容器),Docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongo
mall在linux环境下的部署(基于Docker容器),docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongodb、minio详细教程,拉取镜像、运行容器
mall在linux环境下的部署(基于Docker容器),Docker安装mysql、redis、nginx、rabbitmq、elasticsearch、logstash、kibana、mongo
|
23天前
|
关系型数据库 MySQL Linux
【Azure 应用服务】在创建Web App Service的时候,选Linux系统后无法使用Mysql in App
【Azure 应用服务】在创建Web App Service的时候,选Linux系统后无法使用Mysql in App
【Azure 应用服务】在创建Web App Service的时候,选Linux系统后无法使用Mysql in App
|
11天前
|
域名解析 负载均衡 网络协议
Linux网络接口配置不当所带来的影响
总而言之,Linux网络接口的恰当配置是保证网络稳定性、性能和安全性的基础。通过遵循最佳实践和定期维护,可以最大程度地减少配置错误带来的负面影响。
37 0
|
14天前
|
监控 安全 网络协议
快速配置Linux云服务器
快速配置Linux云服务器
|
23天前
|
开发框架 .NET Linux
【Azure 应用服务】 部署到App Service for Linux 服务的Docker 镜像,如何配置监听端口呢?
【Azure 应用服务】 部署到App Service for Linux 服务的Docker 镜像,如何配置监听端口呢?
|
23天前
|
应用服务中间件 Linux PHP
【Azure 应用服务】App Service For Linux 环境中,如何修改 Nginx 配置中 server_name的默认值 example.com
【Azure 应用服务】App Service For Linux 环境中,如何修改 Nginx 配置中 server_name的默认值 example.com
|
21天前
|
弹性计算 关系型数据库 数据库
手把手带你从自建 MySQL 迁移到云数据库,一步就能脱胎换骨
阿里云瑶池数据库来开课啦!自建数据库迁移至云数据库 RDS原来只要一步操作就能搞定!点击阅读原文完成实验就可获得一本日历哦~
|
25天前
|
关系型数据库 MySQL 数据库
RDS MySQL灾备服务协同解决方案构建问题之数据库备份数据的云上云下迁移如何解决
RDS MySQL灾备服务协同解决方案构建问题之数据库备份数据的云上云下迁移如何解决

热门文章

最新文章