Linux下安装mysql(1)(CentOS)
标题是(1)也就是说这次是基础安装,这种方式安装,没有组的创建,权限管理,配置文件更改等,仅仅是最基本的安装,适合第一次在linux上安装mysql的新手
1.准备好安装包(Linux-Generic表示对各种linux发行版本通用的mysql安装包)

2.解压缩(既然第一次安装,目录随便选)
tar -zxvf mysql-8.0.11-linux-glibc2.12-x86_64.tar.gz -C /usr/local
3.进入目录,改名便于操作
cd /usr/local
mv mysql-8.0.11-linux-glibc2.12-x86_64 mysql
cd mysql/bin

4.此时已经进入到bin目录下了
执行./mysqld --initialize --user=mysql (以mysql用户初始化数据库)
首先这个命令可能会报错

显然mysql这个用户不存在,至于为什么使用mysql这个用户初始化,下面讲.执行useradd mysql创建mysql用户即可(默认生成了mysql组)
创建完成后重新执行./mysqld --initialize --user=mysql ,红色的那行是你的root用户的临时密码

到这里初始化数据库完成,这里可以在执行一下./mysql_ssl_rsa_setup 让你的mysql使用ssl加密连接,(rsa应该是非对称加密算法,记得上学期电商系统安全管理讲到过的)
5.启动mysql
执行 ./mysqld_safe --user=mysql &(以后台方式启动)
会报这个错误,如果你没注意到,待会直接netstat -anp|grep 3306啥也没有

可以看到似乎是mysqld.pid这个文件出了问题
cat下,发现没有,但是find找到了

把路径复制下,同时执行vim /etc/my.cnf 打开配置文件(注意备份)
把pid-file的路径更改为你复制的路径
看到那个user=mysql没?这也是为什么增加mysql这个用户并且用--user=mysql初始化和启动的原因了

更改好,保存退出,然后重新执行
./mysqld_safe --user=mysql & 启动数据库完成

6.连接
到目前位置mysql启动完成了,接下来就是连接了
我做到这里时,ok没问题了然而执行连接数据库的命令后,又报了个错误,大概意思是没办法通过socket建立连接

老办法,find下,似乎是和mysqld.pid同样的问题,路径不对,挂个软连接上去即可

重新登录成功进入,但是还没完,想看数据库,不存在的,必须修改密码,接下来就是很坑的一段记录了,
请不要使用更改user表从而更改密码或者set password...这种更改方法,我全试过了都没用
请执行
ALTER USER "root"@"localhost" IDENTIFIED BY "123";修改密码退出使用新密码重新登录,可以看到开启了ssl加密,也可以查看数据库了

7.总结
①增加mysql用户
②初始化./mysqld --initialize --user=mysql (注意保存此时的临时密码)
③启动前先要修改/etc/my.cnf中(注意备份)的pid-file的路径
④连接数据库之前给mysql.sock挂上软连接,不然找不到
⑤更改密码..
注意上面初始化,启动,连接数据库都是在mysql的bin目录下执行的
最后,想说的是,这种安装只能说是装上去了,并且成功运行了,但是如果你注意观察应该能发现问题,比如权限,全程都是root,mysql目录下的所有文件都是root组
我们需要一个mysql组,来对其进行管理此外还有/etc/my.cnf中其他一些配置选项的更改,全局mysql,还有我遇到的其他一些异常,so只能再写一篇(2)了
Linux下安装mysql(1)(CentOS)的更多相关文章
- Linux下安装mysql(2) 及常见问题解决(CentOS)
上一篇讲了基本的安装,这篇姑且算作进阶吧 链接Linux下安装mysql(1) 1.准备好mysql的rpm安装包 2.解压并进入usr/local/mysql 3.先执行useradd mysql( ...
- linux下安装mysql问题总结(一)mysqld_safe mysqld from pid file /usr/local/mysql/data/mysql.pid ended
linux下安装mysql数据库 linux版本:CentOS release 6.8 (Final) mysql版本:mysql-5.7.16-linux-glibc2.5-x86_64.tar.g ...
- 【云服务器部署】---Linux下安装MySQL
[云服务器部署]---Linux下安装MySQL 有关如何阿里云ECS建网站,推荐一片文章,我是是通过这篇文章安装tomcat和jdk的 网址:阿里云ECS建网站(建站)超详细全套完整图文教程! 注意 ...
- Linux 下安装mysql 5.7
Linux 下安装mysql 5.7 本人首次安装时按照菜鸟教程的步骤一步一步来的,结果意外的是 装成5.6了,而且各种无厘头的问题,例如无法启动... 本文参照 大佬:‘这个名字想了很久~’ 的&l ...
- Linux下安装mysql教程
Linux下安装mysql MySQL官网:https://dev.mysql.com/downloads/mysql/ 到mysql官网下载mysql编译好的二进制安装包,在下载页面Select ...
- Linux 下安装mysql 8.0.11(CentOS 7.4 系统)
CentOS 7 自带MariaDB (前mysql开发工程师开发的,因此与吗,mysql 有很多相似之处) 1.检查卸载自带的MariaDB rpm -qa|grep mariadb //查询出来已 ...
- Linux下安装 MySQL
Ubuntu环境 使用二进制安装包安装,相对简单绿色 1.到官网下载二进制压缩包http://dev.mysql.com/downloads/mysql/ 2.选择需要的版本 目前最新为5.7.之后选 ...
- linux下安装mysql(rpm文件安装)
数据库包下载: https://www.mysql.com/downloads/ 在GPL开原协议的社区开源版里边下载 我们用mysql community server里边的 其中workbench ...
- windows linux 下安装mysql 报1045 等错误
曾经在windows 下安装mysql 没怎么出现过问题.而在linux下安装的时候出现了一些问题,昨天在windows 安装的时候也出现了1045 错误.就个人经历来看这个问题就是 root用户pa ...
随机推荐
- Cocos2d-x学习笔记(一)HelloWorld
原创文章,转载请注明出处:http://blog.csdn.net/sfh366958228/article/details/38656755 前言 正式来公司实习已有一月,前一月主要是看了<C ...
- Datasets for MachineLearning
Public datasets for machine learning http://homepages.inf.ed.ac.uk/rbf/IAPR/researchers/MLPAGES/mld ...
- POJ 1065 Wooden Sticks(zoj 1025) 最长单调子序列
POJ :http://poj.org/problem?id=1065 ZOJ: http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId= ...
- 10、bitmap格式分析
说到图片,位图(Bitmap)当然是最简单的,它Windows显示图片的基本格式,其文件扩展名为*.BMP.在Windows下,任何各式的图片文件(包括视频播放)都要转化为位图个时候才能显示出来,各种 ...
- 14、USB摄像头(V4L2接口)的图片采集
参考网站http://www.cnblogs.com/surpassal/archive/2012/12/19/zed_webcam_lab1.html 一.一些知识 1.V4L和V4L2. V4L是 ...
- [RxJS] Replace zip with combineLatest when combining sources of data
This lesson will highlight the true purpose of the zip operator, and how uncommon its use cases are. ...
- angular自定义指令相关知识及代码
原文地址 https://www.jianshu.com/p/0c015862156d 大纲 1.自定义指令之——属性指令 2.自定义属性指令的运行原理 3.自定义属性指令代码实践 4.自定义结构指令 ...
- STL algorithm算法make_heap和sort_heap(32)
make_heap原型: std::make_heap default (1) template <class RandomAccessIterator> void make_heap ( ...
- Qt多线程学习-用例子来理解多线程(转),这个是我看过最好的文章,总结很详细(感觉exec()的作用就是保持线程不退出,这样方便随时处理主线程发来的信号,是一种非常别致的思路)good
01 class MThread :public QThread 02 { 03 public: 04 MThread(); 05 ~MThread(); 06 virtual ...
- BootStrap让两个控件在一行显示
<div class="row"> <div> <label class="form-inline">参加单位:<in ...