网站首页 > 教程文章 正文
最近新购置一台阿里云4核8G服务器,需要部署mysql,网上安装教程很多,但是由于安装版本以及部署环境不同,出现的问题也是不一样的,需要花时间去处理异常的问题,对于非运维出身的同学或是新手,有安装包和安装文档进行详细记录一下能省很多时间,所以这里记录一下相关操作.这里购置的服务器配置信息:ubuntu16.04 64位.mysql官网下载地址:MySQL :: MySQL Downloads.安装版本:mysql-5.7.16-linux-glibc2.5-x86_64.tar.gz,快捷下载地址:Linux部署mysql,版本号:mysql-5.7.16-linux-glibc2.5-x86_64.tar.gz-Linux文档类资源-CSDN文库,已提供下载安装包以及my.cnf配置文件.以后不用每次去官网下载.下面是具体的安装步骤以及阿里云安全组配置。
1.创建安装目录
mkdir /usr/server/mysql
2.解压安装包(/usr/server/mysql下执行):
tar -xvf mysql-5.7.16-linux-glibc2.5-x86_64.tar.gz
解压结束之后会在/usr/server/mysql下创建mysql-5.7.16-linux-glibc2.5-x86_64文件夹.
3.创建mysql数据存储目录(/usr/server/mysql/mysql-5.7.16-linux-glibc2.5-x86_64下执行):
mkdir -p data
mkdir -p表示允许在创建的文件夹下创建子目录
创建子目录(/usr/server/mysql/mysql-5.7.16-linux-glibc2.5-x86_64/data下执行):
mkdir -p mysql
4.创建mysql组和用户并进行授权(任意目录下依次执行)
groupadd mysql
useradd -r -g mysql mysql
chown mysql:mysql -R /usr/server/mysql/mysql-5.7.16-linux-glibc2.5-x86_64/data/mysql
chown[选项]...[所有者][:[组]]文件... -R处理指定目录以及其子目录下的所有文件
5.编辑配置文件my.cnf
5.1查找my.cnf 位置(根目录下执行):
find / -name my.cnf
到这一步很多同学可能找不到my.cnf.这个和安装版本有关系.这里只介绍5.7.16版本情况,此安装版本中没有my.cnf,可以使用my-default.cnf,将其重命名为my.cnf移动到/etc下。
复制并重命名(/usr/server/mysql/mysql-5.7.16-linux-glibc2.5-x86_64/support-files下执行):
mv /usr/server/mysql/mysql-5.7.16-linux-glibc2.5-x86_64/support-files/my-default.cnf /etc/my.cnf
my-default.cnf默认生成于/usr/server/mysql/mysql-5.7.16-linux-glibc2.5-x86_64/support-files/
5.2编辑配置文件my.cnf
编辑配置文件my.cnf(/etc下执行):
vim /etc/my.cnf
文件中添加内容:
[mysqld]
bind-address=0.0.0.0
port=3306
user=mysql
basedir=/usr/server/mysql/mysql-5.7.16-linux-glibc2.5-x86_64
datadir=/usr/server/mysql/mysql-5.7.16-linux-glibc2.5-x86_64/data/mysql
socket=/tmp/mysql.sock
log-error=/usr/server/mysql/mysql-5.7.16-linux-glibc2.5-x86_64/data/mysql/mysql.err
pid-file=/usr/server/mysql/mysql-5.7.16-linux-glibc2.5-x86_64/data/mysql/mysql.pid
#character config
character_set_server=utf8mb4
symbolic-links=0
或是直接使用第三方连接工具(比如说fileZilla)下载下来之后编辑好之后重新上传即可。
6.数据库初始化(/usr/server/mysql/mysql-5.7.16-linux-glibc2.5-x86_64/bin下执行):
./mysqld --defaults-file=my.cnf位置 --basedir=mysql安装目录 --datadir=数据存放目录 --user=mysql --initialize
本案例中安装示例:
./mysqld --defaults-file=/etc/my.cnf --basedir=/usr/server/mysql/mysql-5.7.16-linux-glibc2.5-x86_64/ --datadir=/usr/server/mysql/mysql-5.7.16-linux-glibc2.5-x86_64/data/mysql/ --user=mysql --initialize
7.启动mysql
先将mysql.server放置到/etc/init.d中 并命名为mysqld,当时没有移动导致启动的时候出现异常:Unit mysqld.service not found.
cp /usr/server/mysql/mysql-5.7.16-linux-glibc2.5-x86_64/support-files/mysql.server /etc/init.d/mysqld
依次启动mysql客户端和服务端(/usr/server/mysql/mysql-5.7.16-linux-glibc2.5-x86_64下执行):
service mysql start
sudo service mysqld start
查看mysql服务是否启动(任意目录执行):
ps -ef|grep mysql
8.登录数据库
8.1启动成功之后登录数据库
查看数据库初始密码(任意目录执行):
cat /usr/server/mysql/mysql-5.7.16-linux-glibc2.5-x86_64/data/mysql/mysql.err
初始密码:
数据库登录(/usr/server/mysql/mysql-5.7.16-linux-glibc2.5-x86_64/bin执行):
./mysql -u root -p
输入之前复制的初始化密码即可登录。
8.2数据库修改初始登录密码
登录数据库成功之后依次执行:
SET PASSWORD = PASSWORD(自定义密码);
ALTER USER 'root'@'localhost' PASSWORD EXPIRE NEVER;
flush privileges;
9.阿里云开放安全组端口
入方向新增自一条记录,mysql端口3306指定可以允许访问的ip。
10.第三方工具连接mysql
第一次使用第三方工具,比如说sqlyog客户端进行远程连接,会遇到的异常:`Host ‘xxx.xxx.xxx.xxx’(本地ip) is not allowed to connect to this MySQL server`,原因是root用户允许访问的ip仅为localhost,需要进行修改.处理方式如下:
登录数据库(依次执行以下命令):
use mysql;
select host from user where user = 'root';
update user set host = '%' where user = 'root';
flush privileges;
按照上述操作步骤,第三方客户端连接成功,问题解决!
补充:mysql服务启动关闭以及运行状态查看命令:
关闭mysql服务(任意目录下执行):
service mysqld stop
查询mysql服务端运行状态(任意目录下执行):
service mysqld status
说明:本文没有进行开机启动mysql的配置,因为购买的阿里云服务器是一直运行的,非特殊情况不会进行频繁启动.如果有特殊情况导致阿里云服务器关闭,只需要在重启服务器之后重新启动一下mysql就可以.
以上是阿里云服务器中部署mysql的实际操作步骤,如果感觉对你所有帮助欢迎评论区留言点赞!
- 上一篇: Mysql 使用中常见的错误
- 下一篇: Linux 下安装最新版 MySQL
猜你喜欢
- 2025-01-11 免费零代码平台一键Docker云安装,快速搭建应用
- 2025-01-11 Linux 下安装最新版 MySQL
- 2025-01-11 Mysql 使用中常见的错误
- 2025-01-11 【Docker】部署Jira&Confluence
- 2025-01-11 Mysql:下载、安装、部署、修改密码步骤
- 2025-01-11 修改编码格式MySQL
- 2025-01-11 erpnext V15安装
- 2025-01-11 MySQL常见错误处理方法
- 2025-01-11 MySQL5.7升级到8.0过程详解
- 2025-01-11 Cannal实现MySQL主从同步环境搭建
- 最近发表
-
- 一个可以用来练手的C++开源编译器!
- Linux开发工具使用指南(linux软件开发工具)
- Linux下Makefile文件的模式规则和自动化变量
- 程序员的副业秘籍!一款可以快速搭建各类系统的后台管理系统
- postgresql自定义函数实现,通过contrib模块进行扩展
- Linux GCC编译及Makefile使用(gcc makefile编写)
- wordpress独立站上线两周没收录?原来是robots.txt搞的鬼…
- make sure用法解析(make sure sth)
- 每天一个 Python 库:Django全能Web框架,一站式后台开发
- Makefile实践(makefile经典教程)
- 标签列表
-
- location.href (44)
- document.ready (36)
- git checkout -b (34)
- 跃点数 (35)
- 阿里云镜像地址 (33)
- qt qmessagebox (36)
- mybatis plus page (35)
- vue @scroll (38)
- 堆栈区别 (33)
- 什么是容器 (33)
- sha1 md5 (33)
- navicat导出数据 (34)
- 阿里云acp考试 (33)
- 阿里云 nacos (34)
- redhat官网下载镜像 (36)
- srs服务器 (33)
- pico开发者 (33)
- https的端口号 (34)
- vscode更改主题 (35)
- 阿里云资源池 (34)
- os.path.join (33)
- redis aof rdb 区别 (33)
- 302跳转 (33)
- http method (35)
- js array splice (33)