文档章节

使用二进制包安装mysql

o
 osc_x4h57ch8
发布于 2018/04/24 11:40
字数 671
阅读 0
收藏 0

精选30+云产品,助力企业轻松上云!>>>

Mysql官网二进制包下载地址

https://dev.mysql.com/downloads/mysql/

选择对应版本下载

根据操作系统选择

会有一步让注册的  点击“No thanks, just start my download.” 即可直接下载

常用目录介绍

#笔者自己的习惯
/data/ /data/mysql 安装目录 /data/mysql33306 数据目录 /data/mysql3306/mysql.sock /data/mysql/ini/my.cnf /data/mysql3306/error.log /data/mysql3306/mysql3306.pid

安装所需组件

yum install libaio

解压并创建数据目录

mkdir -p /data/mysql
mkdir -p /data/mysql3306/
tar -zxvf mysql-5.7.16-linux-glibc2.5-x86_64.tar.gz
mv mysql-5.7.16-linux-glibc2.5-x86_64 /data/mysql

添加mysql环境变量

##注意 将自己安装的mysql的环境变量添加在前边,否则直接使用mysql的相关命令的时候如果用的是系统自带的有时候会报错
echo 'export PATH=/data/mysql/bin:$PATH' >>/etc/profile
source /etc/profile
which mysql  查看时候生效  
#/data/mysql/bin/mysql

添加mysql用户

groupadd mysql
useradd -r -g mysql -s /bin/false mysql

添加目录权限

chown mysql:mysql /data/mysql3306 -R
chown mysql:mysql /data/mysql -R

配置myql文件

[client]
default-character-set = utf8mb4

[mysql]
default-character-set = utf8mb4

[mysqld]
character-set-server=uft8mb4
basedir = /data/mysql 
datadir = /data/mysql3306/
port = 3306
socket = /data/mysql3306/mysql.sock
pid-file = /data/mysql3306/mysql3306.pid

log-error = /data/mysql3306/error.log
server-id=1
slow-query-log = 1
long_query_time = 0.2
slow-query-log-file = /data/mysql3306/slow-queries.log

max_connections = 800
max_connect_errors = 100000

table_open_cache = 256
query_cache_size = 2M

character_set_server=utf8
init_connect='SET NAMES utf8'

innodb_file_per_table=1
innodb_buffer_pool_size = 2048M
innodb_data_file_path = ibdata1:1024M:autoextend

innodb_flush_log_at_trx_commit=1 
innodb_log_buffer_size = 16M
innodb_log_file_size = 256M
innodb_log_files_in_group = 2 
innodb_max_dirty_pages_pct = 50 

log-bin = mysql-bin
sync_binlog=1
binlog-format=row
expire_logs_days = 10

interactive_timeout = 1800
wait_timeout = 1800

log_timestamps = system
my.cnf 参考内容

初始化

/data/mysql/bin/mysqld --defaults-file=/data/mysql/ini/my.cnf --initialize-insecure --explicit_defaults_for_timestamp --basedir=/data/mysql --datadir=/data/mysql3306/ --user=mysql
# --initialize-insecure 设置root 空密码

 启动服务

/data/mysql/bin/mysqld_safe  --defaults-file=/data/mysql/ini/my.cnf --user=mysql &
ps -ef|grep mysql 检查进程是否启动

登陆mysql

/data/mysql/bin/mysql -uroot -p --socket = /data/mysql3306/mysql.sock

安装完毕后的操作

设置root密码(如果使用root的话,应该删除root,创建一个新的特权用户)
mysqladmin -u root password  123 --socket=/data/mysql3306/mysql.sock

创建特权用户admin 删除root
grant all privileges on *.* to 'admin'@'%' identified by '123' with grant option;
flush privileges;

drop user 'root'@'localhost';

查看所有用户
SELECT DISTINCT CONCAT('User: ''',user,'''@''',host,''';') AS query FROM mysql.user;

关闭mysql的方法
/data/mysql/bin/mysqladmin -u root –p’123’  -S /data/mysql3306/mysql.sock shutdown
/data/mysql/bin/mysqladmin -u admin -p  -S /data/mysql3306/mysql.sock shutdown (如果root用户已经被删除的话)


重设密码
update mysql.user set authentication_string=password('YfD18$d079f!#DA') where user='root' and Host = 'localhost';
flush privileges;

alias mysql='mysql --socket=/data/mysql3306/mysql.sock  -uadmin -p123'
#!/bin/bash
/data/mysql/bin/mysqld_safe  --defaults-file=/data/mysql/ini/my.cnf --user=mysql &
start.sh
#!/bin/bash
/data/mysql/bin/mysqladmin -u admin -p  -S /data/mysql3306/mysql.sock shutdown
stop.sh

 

关于my.cnf里安装完毕后需要重新加一句

sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES

在线修改方式

#查看
SELECT @@sql_mode;
#修改
set GLOBAL sql_mode ='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION ';

在线修改完毕后 开发的navicat需要重新连接一下

o
粉丝 0
博文 500
码字总数 0
作品 0
私信 提问
加载中
请先登录后再评论。

暂无文章

Linux系统检查用户账户到期时间

如果你在 Linux 上启用了密码策略。密码必须在到期前进行更改,并且登录到系统时会收到通知。如果你很少使用自己的帐户,那么可能由于密码过期而被锁定。在许多情况下,这可能会在无需密码登...

老孟的Linux私房菜
38分钟前
13
0
关于南京哪里有开餐饮费发票?

关于南京哪里有开餐饮费发票?聚焦餐饮行业,谈话〖18 7一電一7 5 3 8一徴一3331〗研究院昨发布数据显示,今年上半年,全国餐饮行业招聘需求增长46.18%,平均月薪6387元.随着餐饮行业的快速...

点击fojewio
今天
7
0
android studio 4.0 打开DDMS

1、先找到AndroidStudio配置的SDK路径; 2、在SDK的/tools/路径下有个monitor.bat 的批处理文件; 3、鼠标连续点击两下monitor.bat这个批处理文件,在屏幕上会打开一个类似CMD的命令行中输入...

chenhongjiang
今天
10
0
如何在Android中使用SharedPreferences来存储,获取和编辑值

问题: Closed . 已关闭 。 This question needs to be more focused. 这个问题需要更加集中。 It is not currently accepting answers. 它当前不接受答案。 Learn more . 了解更多 。 Want...

fyin1314
今天
6
0
【JDK1.8】LinkedList源码分析

LinkedList的特性 LinkedList内部使用双向链表作为存储结构,LinkedList可以理解为链表的扩展对象,封装了常用的和非常用的操作链表的方法。以及在通过索引获取元素时的简单优化,通常Linke...

XuePeng77
今天
40
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部