当前位置: 首页 > news >正文

MySQL5.7之源码安装

文章目录

  • 下载
  • 编译&打包
  • 初始化数据目录
  • 启动服务器
  • 更改/设置root密码

下载

下载地址:https://downloads.mysql.com/archives/community/

推荐下载 All Operating Systems (Generic) (Architecture Independent), Compressed TAR ArchiveIncludes Boost Headers 这个带Boost Headers的版本

编译&打包

安装包下载解压后。执行以下命令,编译之前需要cmake、make相关的工具。如果没有需要自行安装。

cd mysql-5.7 ##自己解压的目录里
mkdir mysql-build && cd mysql-build ## 新建一个目录用来编译
cmake -DWITH_BOOST=/path/boost ../ ## 5.7编译需要用到boost,这里需要制定路径。
make && make package ## 这个命令可以构建package.tar.gz 安装。
##或者执行
make && make install DESTDIR=/path/mysql ## 这个命令可以执行构建并按照到目录/path/mysql 

初始化数据目录

参考MySQL数据目录初始化过程
通过RPM包、DMG包、EXE等形式安装的MySQL会自动初始化数据目录。通过源码、tar.gz、zip包安装的MySQL需要手动初始化数据目录。

./bin/mysqld --initialize --user=mysql --basedir=/opt/mysql/mysql --datadir=/opt/mysql/mysql/data

在初始化数据目录时,您不应该指定除用于设置目录位置(如--basedir或--datadir)以及(如果需要)--user选项之外的任何选项。MySQL服务器在正常使用过程中将使用的选项可以在初始化后重新启动时设置。
也可以在配置文件 my.cnf 中添加

[mysqld]
basedir=/opt/mysql/mysql
datadir=/opt/mysql/mysql/data

然后执行以下命令,下面的命令等同于 bin/mysqld --initialize --user=mysql --basedir=/opt/mysql/mysql --datadir=/opt/mysql/mysql/data

bin/mysqld --defaults-file=/opt/mysql/mysql/etc/my.cnf  --initialize --user=mysql

启动服务器

如果按照目录中有 mysqld_safe脚本,启动mysql 服务器

./bin/mysqld_safe --user=mysql &
## 由于我这里修改了默认的数据目录,所以这里启动需要执行数据目录
./bin/mysqld_safe --user=mysql --basedir=/opt/mysql/mysql --datadir=/opt/mysql/mysql/data

在Linux系统上,如果MySQL是通过RPM包安装的,那么服务器的启动和关闭通常是通过systemd来管理的,而不是通过mysqld_safe。

mysqld_safe是一个启动脚本,它提供了额外的安全性、错误检测和记录。它通常用于以安全的方式启动MySQL服务器。

MySQL服务器应该使用无特权(非root)登录帐户运行。为确保这一点,请以root身份运行mysqld_safe,并包含如所示的–user选项。否则,您应该在登录为mysql用户时执行该程序,在这种情况下,您可以从命令中省略–user选项。

如果服务器无法访问数据目录,或者无法启动、读取mysql数据库中的授权表。如果在执行启动服务器之前忽略了通过初始化数据目录来创建授权表,或者您在没有--user选项的情况下运行了初始化数据目录的命令,就可能会出现此类问题。请删除数据目录并使用--user选项重新运行初始化数据目录命令。

更改/设置root密码

在初始化数据目录的过程中,如果有参数 --initialize,root账号会随机生成密码;如果有参数 --initialize-insecure,root不会设置密码(参考MySQL数据目录初始化过程)。这时候都需要重置root密码。

ALTER USER 'root'@'localhost' IDENTIFIED BY 'root-password';
flush privileges;

相关文章:

MySQL5.7之源码安装

文章目录 下载编译&打包初始化数据目录启动服务器更改/设置root密码 下载 下载地址:https://downloads.mysql.com/archives/community/ 推荐下载 All Operating Systems (Generic) (Architecture Independent), Compressed TAR ArchiveIncludes Boost Headers …...

【Linux学习 | 第3篇】Linux系统安装 jdk+Tomcat+MySQL+lrzsz

文章目录 Linux—day31. 软件安装方式2. 安装jdk3. 安装Tomcat3.1 安装步骤:3.2 防火墙操作3.3 停止Tomcat服务的方式 4. 安装MySQL5. 安装lrzsz5.1 操作步骤 Linux—day3 Linux系统中软件安装 1. 软件安装方式 二进制发布包安装:软件已经针对具体平台…...

python语言day5 MD5 json

md5: python提供了内置的md5加密功能,使用md5模拟一个小项目: 注册: 启动py程序,在控制台界面提示用户输入用户名及密码; 使用md5加密 密码; 创建txt文件记录输入的用户名 和密文。 登录&…...

【Python学习手册(第四版)】学习笔记19-函数的高级话题

个人总结难免疏漏,请多包涵。更多内容请查看原文。本文以及学习笔记系列仅用于个人学习、研究交流。 本文主要介绍函数相关的高级概念:递归函数、函数注解、lambda表达式函数,常用函数工具如map、filter、reduce,以及通用的函数设…...

Selenium + Python 自动化测试11(unittest组织用例)

我们的目标是:按照这一套资料学习下来,大家可以独立完成自动化测试的任务。 上一篇我们讨论了unittest基本使用方法。 本篇文章我们接着讲。一些概念和一些常用的构造测试集的方法。 1、基本概念 1)Test Case 一个Test Case的实例就是一个测…...

【唐氏题目 nt题】与众不同

# 与众不同 ## 题目描述 A是某公司的CEO,每个月都会有员工把公司的盈利数据送给A,A是个与众不同的怪人,A不注重盈利还是亏本,而是喜欢研究「完美序列」:一段连续的序列满足序列中的数互不相同。 A想知道区间[L,R]之…...

2000块的活嫌低?这个 6 位数的项目,你可不能错过哟!

2000块钱嫌低?这个6位数的项目,你可不能错过,关注有好礼。 最近写了一篇“接了一个2000块钱的活,大家看看值不值”的文章,发现流量和大家互动的热情出奇的高,可能是跟有钱有关的缘故,大家不是奔…...

【Postman工具】

一.接口扫盲 1.什么是接口? 接口是系统之间数据交互的通道。拿小红到沙县点餐为例:小红想吃鸭腿饭。她要用什么语言来表达?跟谁表达?通过什么表达?按照生活习惯应该是:小红根据菜单对服务员用中文表达她想要…...

全网超详细攻略-从入门到精通haproxy七层代理

目录 一.haproxy概述 1.1 haproxy简介 1.2 haproxy的主要特性 1.3 haproxy的优缺点 二.负载均衡介绍 2.1 什么是负载均衡 2.2 为什么用负载均衡 2.3 负载均衡类型 2.3.1 四层负载均衡 2.3.2 七层负载均衡 2.3.3 四层和七层的区别 三.haproxy的安装及服务 3.1 实验环…...

AI编程辅助工具:CodeGeeX 插件使用

CodeGeeX 插件使用 前言1.支持的平台2.安装步骤3.启用插件4.代码生成5.代码优化 前言 CodeGeeX 是一款基于 AI 技术的编程助手插件,旨在帮助开发者提高编程效率和代码质量。它能够智能生成代码、优化现有代码、自动生成文档以及回答编程相关的问题。无论您是初学者…...

sql注入实战——thinkPHP

sql注入实战——thinkPHP sql注入实战——thinkPHPthinkPHP前期环境搭建创建数据库开始寻找漏洞点输入SQL注入语句漏洞分析 实验错误 sql注入实战——thinkPHP thinkPHP前期环境搭建 下载thinkPHP文件 解压,将framework关键文件放到think-5.0.15中,改…...

MySQL 迁移 OceanBase 的 Oracle模式中,实现自增主键的方法

本文作者:赵黎明,爱可生 MySQL DBA 团队成员,熟练掌握Oracle、MySQL等数据库系统,擅长对数据库性能问题的诊断,以及事务与锁机制的分析等。负责解决客户在MySQL及爱可生自主研发的DMP平台日常运维中所遇到的各种问题&a…...

【C++ 面试 - 基础题】每日 3 题(十一)

✍个人博客:Pandaconda-CSDN博客 📣专栏地址:http://t.csdnimg.cn/fYaBd 📚专栏简介:在这个专栏中,我将会分享 C 面试中常见的面试题给大家~ ❤️如果有收获的话,欢迎点赞👍收藏&…...

ESP8266在线升级OTA固件

OTA的基本实现方式: ESP8266 的 OTA 实现有几种方式,常用的方式包括: 1、Arduino OTA:使用Arduino IDE提供的OTA功能,可以直接通过Arduino IDE上传固件到ESP8266。 2、Web OTA:ESP8266运行一个简易的Web服…...

精通C++ STL(六):list的模拟实现

目录 类及其成员函数接口总览 结点类的模拟实现 构造函数 迭代器类的模拟实现 迭代器类存在的意义 迭代器类的模板参数说明 构造函数 运算符的重载 --运算符的重载 运算符的重载 !运算符的重载 *运算符的重载 ->运算符的重载 list的模拟实现 默认成员函数 构造函数 拷贝…...

《雅思口语真经总纲1.0》话题实战训练笔记part1——6. Music

《雅思口语真经总纲1.0》笔记——第四章:口语素材大全(part1、part2、part3回答准则及练习方法,不包括范例答案)★★★★★ 文章目录 MusicWhen do you listen to music?20240804答评价注意事项1、在说到“no music”时&#xff…...

Python之赋值语句(多重赋值和交换赋值)

这是《Python入门经典以解决计算问题为导向的Python编程实践》73-74页关于赋值的内容。讲了Python中几种赋值方式。 赋值语句 1、最简单的赋值:ab2、多重赋值:a,b,c1,2,33、交换:a,bb,a 1、最简单的赋值:ab b可以是数字、字符串…...

网络协议七 应用层 HTTP 协议

应用层常见的协议 HTTP协议 1. 如何查看我们的http 协议全部的内容有哪些呢? 一种合理的方法是 通过 wireshark 软件,找到想要查看的HTTP --->追踪流--->HTTP流 来查看 结果如下:红色部分 为 发送给服务器的,蓝色部分为服务…...

uniapp vue 在适配百度小程序平台动态:style

uniapp vue 在适配百度小程序平台动态:style踩坑报错Unexpected string concatenation of literals 抖快平台动态style写法基本是 <view :style"{width: 686rpx, height: (setHeight 96) rpx}"> </view>这种写法在百度上会又解析报错&#xff1a; Une…...

【最小生成树】(二) Kruskal 算法

题目: 寻宝 题目描述 在世界的某个区域&#xff0c;有一些分散的神秘岛屿&#xff0c;每个岛屿上都有一种珍稀的资源或者宝藏。国王打算在这些岛屿上建公路&#xff0c;方便运输。 不同岛屿之间&#xff0c;路途距离不同&#xff0c;国王希望你可以规划建公路的方案&#xf…...

SEO整站优化服务需要哪些专业技能_SEO整站优化服务如何提高网站的技术优化

SEO整站优化服务需要哪些专业技能_SEO整站优化服务如何提高网站的技术优化 在当今数字化时代&#xff0c;网站的成功与否在很大程度上取决于其在搜索引擎上的排名。SEO整站优化服务作为提高网站可见度和流量的关键手段&#xff0c;需要一系列专业技能的支持。本文将详细探讨SE…...

MATLAB代码:基于主从博弈的电热综合能源系统DE算法优化动态定价与能量管理

MATLAB代码&#xff1a;基于主从博弈的电热综合能源系统动态定价与能量管理 关键词&#xff1a;主从博弈 电热综合能源 动态定价 能量管理 仿真平台&#xff1a;MATLAB 平台 优势&#xff1a;代码具有一定的深度和创新性&#xff0c;注释清晰&#xff0c;非烂大街的代码&…...

保姆级教程:彻底解决Win11 CH340串口‘无法访问’问题(附2011版驱动下载与防捆绑指南)

终极指南&#xff1a;Win11系统CH340串口驱动兼容性问题的完整解决方案 最近不少开发者反馈在Windows 11系统下使用CH340串口模块时遇到了"无法访问"的问题。这个看似简单的驱动兼容性问题&#xff0c;实际上困扰了许多嵌入式开发者和硬件爱好者。本文将提供一个从问…...

从零搭建一个智能客服问答引擎:基于T5模型与PyTorch的完整项目实战

从零搭建智能客服问答引擎&#xff1a;基于T5模型与PyTorch的工业级实践 当企业客服系统每天需要处理数千条重复性问题时&#xff0c;人工坐席的效率瓶颈就会凸显。去年为某电商平台部署智能客服系统的经历让我深刻体会到&#xff1a;一个能理解"我的快递为什么三天没更新…...

如何快速将网页转换为Figma设计稿:5分钟完成HTML到Figma的无缝转换

如何快速将网页转换为Figma设计稿&#xff1a;5分钟完成HTML到Figma的无缝转换 【免费下载链接】figma-html Convert any website to editable Figma designs 项目地址: https://gitcode.com/gh_mirrors/fi/figma-html HTML到Figma转换工具是一款能够将任何网站转换为可…...

crypto-js —— 前端数据安全的 JavaScript 加密利器

1. 为什么前端开发需要数据加密&#xff1f; 想象一下这样的场景&#xff1a;你在网上填写了一份包含个人信息的表单&#xff0c;点击提交后&#xff0c;这些数据会以明文形式在网络中传输。如果有人在传输过程中截获了这些数据&#xff0c;你的隐私就会完全暴露。这就是为什么…...

2025届最火的六大降重复率助手推荐

Ai论文网站排名&#xff08;开题报告、文献综述、降aigc率、降重综合对比&#xff09; TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 能降低AIGC检测率的关键之处在于模拟人类写作所具备的自然性以及逻辑跳跃。其一&#xff0c;…...

Hikyuu性能优化技巧:从AMD 7950x实测看量化平台的极致速度

Hikyuu性能优化技巧&#xff1a;从AMD 7950x实测看量化平台的极致速度 【免费下载链接】hikyuu Hikyuu Quant Framework 基于C/Python的极速开源量化交易研究框架&#xff0c;同时可基于策略部件进行资产重用&#xff0c;快速累积策略资产。 项目地址: https://gitcode.com/g…...

4.4【A】

进程之间不能直接访问对方内存所以必须用 Socket 共享内存 通信每个进程独立运行每个进程自己负责自己的连接网卡模拟器进程&#xff1a;监听 PCIe 连接QEMU 进程&#xff1a;主动连接 PCIe它们通过 Socket 建立连接&#xff0c;交换自我介绍然后用共享内存高速通信底层状态初…...

Kotlin协程取消机制实战:用suspendCancellableCoroutine避免你的后台任务内存泄漏

Kotlin协程取消机制实战&#xff1a;用suspendCancellableCoroutine避免内存泄漏 当你在安卓应用中处理一个耗时任务时&#xff0c;用户突然退出页面会发生什么&#xff1f;那些未完成的网络请求、数据库查询和文件操作可能仍在后台默默消耗资源。更糟的是&#xff0c;如果这些…...