华为云服务器以编译方式安装mysql(附带常见报错解决方案)

news2024/11/26 22:26:17

文章内容较长,请参考目录进行操作。

目录

1、检测系统是否自带mysql

2、下载MySQL

3、安装MySQL

4、环境变量配置

5、下载/升级依赖

1)定位问题

 2)解决问题

gcc版本过低:

使用devtoolset来升级gcc版本

1)安装 centos-release-scl

2)安装 devtoolset

3)激活

注意 

可能报错:

解决办法:

 手动编译

下载安装包:

安装 isl:

编译安装gcc

安装并编译gcc:

编译过程中可能报错:

collect2: ld terminated with signal 9

gcc: fatal error: cannot execute ‘cc1plus’: execvp: No such file or directory

没有替换老版本gcc动态库:

6、启动mysql


1、检测系统是否自带mysql

rpm -qa | grep mysql #检查是否安装过MySQL

rpm -qa | grep mariadb #检查是否存在 mariadb 数据库(内置的MySQL数据库),有则强制删除

rpm -e --nodeps mariadb-libs-5.5.68-1.el7.x86_64 #强制删除

rpm -e --nodeps mariadb-5.5.68-1.el7.x86_64 #强制删除

若在删除时提示“mariadb-xxx is not installed”那极为可能是你输入的有误,在Xshell中我们可以鼠标选中查出的信息,右键-复制,再粘贴到你输入的位置即可(一定要右键再选择复制和粘贴,不可以直接使用ctrl+快捷键)

2、下载MySQL

我的项目用的版本是mysql8.0的版本,因此只找了8.0的下载链接,不过5.7的安装步骤之类也是一致的,这个不用担心。无非是下载时选择的版本不同

社区版下载链接:MySQL :: Download MySQL Community Server

进入之后就可以选择下载8.0还是5.7了,不同版本的安装步骤只有这一步不同。

选择要下载的系统

也可以更细致一些,选择适合自己的系统内核 

 最后,不论上面选择的是哪些选项,都要认准这个下载选项。

 (偷摸摸说一句,使用迅雷下载的话速度比官网快很多)

3、安装MySQL

下载完安装包后,就可以使用XFTP上传到服务器上了(建议将软件都安装在/usr/local目录下)

解压命令“tar -zxvf mysql-xxx”

解压完毕后重命名,和安装jdk的过程很类似

不同的是,云服务器安装mysql缺少依赖,可执行“yum -y install numactl”下载相应依赖包

安装常用软件工具命令“yum -y install vim net-tools lrzsz gcc gcc-c++1”

4、环境变量配置

安装完成后就可以开始配置环境变量了

使用命令进入 /etc/profile 目录,配置环境变量

在刚刚配置的jdk的配置文件后,再加一段“export PATH=$PATH:/usr/local/mysql/bin”

ESC-“:wq”退出保存

再次使用命令“source /etc/profile”更新配置

 

5、下载/升级依赖

初始化mysql时,输入命令“mysqld --initialize --user mysql”进行数据库初始化,而此时会报错“error while loading shared libraries: libaio.so.1: cannot open shared object file: No such file or directory”

这个问题产生原因是因为服务器刚开始什么环境和配置都没有,需要下载依赖。

输入命令“yum install -y libaio”下载依赖即可

下载完成后再次执行初始化命令,此时会报错一大堆

产生这个问题的原因有两种:

  1. gcc版本过低
  2. 升级gcc时生成的动态库没有替换老版本gcc的动态库,将gcc最新版本的动态库替换系统中老版本的动态库即可解决

1)定位问题

如何确定自己属于哪一类呢?

通过 strings /usr/lib64/libstdc++.so.6 | grep GLIBC 命令检查动态库

由图上可知,我的gcc的动态库还是旧版本GLIBCXX_3.4.19的

查找编译gcc时生成的最新动态库:find / -name "libstdc++.so*"

/usr/lib64是gcc当前的动态库路径,可以看到该动态库已经是最新的gcc版本动态库了。

因此,问题就属于gcc版本过低。

若在查找最新动态库时发现有更新版本的gcc,那就属于没有替换的问题。

 2)解决问题

gcc版本过低:

使用devtoolset来升级gcc版本

1)安装 centos-release-scl

yum install centos-release-scl

2)安装 devtoolset

命令中的9 代表gcc版本,一般安装高版本后低版本的gcc都会自动安装,选择自己适合的版本就可以。

//安装gcc 9 的版本

yum -y install devtoolset-9-gcc*

//安装gcc 7 的版本

yum -y install devtoolset-7-gcc*

3)激活

//激活gcc 9

scl enable devtoolset-9 bash

//激活gcc 7

scl enable devtoolset-7 bash

注意 

1.升级完成后一定要运行:gcc --version 看一下版本号变成升级后的gcc版本才算升级成功。


2.scl命令启用只是临时的,退出shell或重启就会恢复原系统gcc版本。

如果要长期使用的话执行:echo "source /opt/rh/devtoolset-7/enable" >>/etc/profilegcc版本9 执行:echo "source /opt/rh/devtoolset-9/enable" >>/etc/profile

 gcc版本9 执行:echo "source /opt/rh/devtoolset-9/enable" >>/etc/profile

3.升级过gcc后还要进行替换老版本gcc动态库的操作

可能报错:

原因在于系统upgrade的时候,残存了上一个版本的软件包信息(比如升级到了attr-2.4.44,但系统中存在了之前缓存的软件包信息)

解决办法:

1).配置正确的yum源

yum install epel-release

2).执行相关命令

yum clean all  ##清除本地yum缓存

yum distro-sync ##同步本地软件和epel源的软件包信息

至此问题基本解决

 手动编译

下载安装包:

原地址:Index of /gnu/gcc

国内使用:Index of /gnu/gcc/

终端内操作

wget http://ftp.gnu.org/gnu/gcc/gcc-9.1.0/gcc-9.1.0.tar.gz

tar  -zcvf gcc-9.1.0.tar.gz

不要直接编译安装的,先检查一下依赖有没有装好。

cd gcc-9.1.0

./contrib/download_prerequisites

因为我这里都安装了,所以显示成功

若检查过程中发现有缺少相应的依赖,则使用对应的命令进行下载。

yum install gmp-devel

yum install mpfr-devel

yum install libmpc-devel

安装 isl:

wget ftp://gcc.gnu.org/pub/gcc/infrastructure/isl-0.18.tar.bz2

tar -jxvf isl-0.18.tar.bz2

cd isl-0.18 

./configure   

make  

make install   

安装完成后再次检查:

./contrib/download_prerequisites

编译安装gcc

安装开发环境依赖:

yum groupinstall "Development Tools"

yum install glibc-static libstdc++-static

安装并编译gcc:

cd gcc-9.1.0

mkdir gcc-build-9

cd gcc-build-9

../configure --prefix=/usr/local/gcc9 --enable-languages=c,c++,go  --disable-multilib

make -j4

(-j4选项是make对多核处理器的优化,如果不成功请使用 make。建议不要使用make -j来编译,虽然可以缩短编译时间,但极大可能会编译失败)

编译过程中可能报错:
collect2: ld terminated with signal 9

这个报错的原因是华为云并没有默认创建swap分区,使用“free -m”命令查看空余空间,可以看到它的大小是0,也就意味着根本没有给swap分配磁盘。

 那么我们有两种方法可以选:

1. 新建磁盘分区作为swap分区(磁盘空间充足)

        1)卸载所有swap分区

           以root身份进入控制台(登录系统)

           swapoff -a #停止所有的swap分区

        2)对新增磁盘进行分区

            用fdisk命令(例:# fdisk /dev/sdb)对磁盘进行分区,添加swap分区,新建分区,在fdisk中用“t”命令将新添的分区id改为82(Linux swap类型),最后用w将操作实际写入硬盘(没用w之前的操作是无效的)。

        3)对分区进行格式化(格式化为swap分区)

           # mkswap /dev/sdb2 #格式化swap分区,这里的sdb2要看您加完后p命令显示的实际分区设备名

2. 新建文件(磁盘空间并不充足)

        1)创建要作为swap分区的文件  

        例如:增加1GB大小的交换分区,则命令写法如下,其中的count等于想要的块的数量(bs*count=文件大小)

        # dd if=/dev/zero of=/root/swapfile bs=1M count=1024

        2)格式化为交换分区文件

        # mkswap /root/swapfile #建立swap的文件系统

        # chmod 600 /root/swapfile #修改权限

        3)启用交换分区文件

        # swapon /root/swapfile #启用swap文件

        4)使系统开机时自启用

        在文件/etc/fstab中添加一行: /root/swapfile swap swap defaults 0 0

        扩展完分区后再进行编译,还是报错

gcc: fatal error: cannot execute ‘cc1plus’: execvp: No such file or directory

 可能的原因:

        问题定位: g++ --version gcc --version

        没有版本号的话安装1)所示安装编译器,有的话按照2)所示运行查找命令

        1)没有安装c++编译器

                解决方式:apt install g++   ## 安装c++编译器

        2)未添加到环境变量中

                解决方式:运行: find / -name "cc1plus"

完成之后,运行make install

没有替换老版本gcc动态库:

查找编译gcc时生成的最新动态库:find / -name "libstdc++.so*"

/usr/local/gcc-9.2.0/lib64/是升级gcc时的输出路径,

使用命令“cp /usr/local/gcc-9.2.0/lib64/libstdc++.so.6.0.27 /usr/lib64”将最新动态库libstdc++.so.6.0.27复制到/usr/lib64路径下(根据自己的路径设置):

重建默认库的软连接:

cd /usr/lib64

ll

rm -rf libstdc++.so.6

ln -s libstdc++.so.6.0.27 libstdc++.so.6

依次执行完毕后再次检查动态库升级完情况

strings /usr/lib64/libstdc++.so.6 | grep GLIBC

可见gcc库版本已经扩展到27了,证明gcc安装成功。

6、启动mysql

此时再使用命令“mysqld --initialize --user mysql”

进行mysql初始化登录即可

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/938559.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

实例045 使用任意组件拖动窗体

实例说明 通常将鼠标按住窗口的标题栏才能够拖动窗口,但是,在没有窗口标题栏的情况下如何拖动窗体呢?本例将会利用窗口中的控件拖动窗口,将鼠标放在按钮上然后按住鼠标左键移动鼠标即可拖动窗体。实例效果如图1.46所示。 技术要点…

​什么是502 bad gateway 报错和解决办法

什么是502 bad gateway 报错 简单来说 502 是报错类型代码 bad gateway 错误的网关。是Web服务器作为网关或代理服务器时收到无效的响应。 用我们的口语说就是运行网站的服务器暂时挂了(不响应)。 产生错误的原因 1.连接超时 我们向服务器发送请求 由于服务器当前链接太多&am…

vue三级市区联动

默认返回值格式:all:code、name都返回 name:只返回name code:只返回code,level:可设置显示层级 1: 省 2: 省、市 3: 省、市、区 v-model 默认值 可以是 name: [ "天津市", "天津市",…

Datatable:Python数据分析提速高手,飞一般的感觉!

1 前言 Datatable是一个Python库: 详细介绍大家可以去官网查看: https://datatable.readthedocs.io/en/latest/?badgelatest Datatable的有点包括: 高效的多线程算法 Memory-thrifty 内存映射磁盘上的数据集 本地C实现 完全开源 Da…

iTunes怎么备份?1招教你轻松搞定

相比于苹果手机的iCloud备份,使用iTunes备份具有以下优点:1、备份容量不受限制;2、备份后的文件就像普通文档一样,可以随时进行查看和管理。本文将为大家介绍itunes怎么备份、如何对备份进行加密以及怎么删除备份的方法&#xff0…

nginx配置keepalive长连接

nginx之keepalive详解与其配置_keepalive_timeout_恒者走天下的博客-CSDN博客 为什么要有keepalive? 因为每次建立tcp都要建立三次握手,消耗时间较长,所以为了减少tcp建立连接需要的时间,就可以设置keep_alive长连接。 nginx中keep_alive对…

Java:Map集合的三种遍历方式和常见案例

Map集合的遍历方式 方式一:键找值 遍历方式二:键值对 遍历方式三:Lambda表达式 Map集合的常见案例 需求 某个班级80名学生,现在需要组织秋游活动,班长提供了四个景点依次是(A、B、C、D),每个学生只能选择一个景点&am…

阿里云CDN缓存预热与刷新以及常见的故障汇总

文章目录 1.为CDN缓存的文件增加过期时间2.CDN缓存预热配置3.CDN缓存刷新配置4.常见故障 CDN缓存预热指的是主动将要缓存的文件推送到全国各地的CDN边缘加速器上,减少回源率,提供命中率。 缓存刷新指的是后期上传了同名的文件,之前的缓存已经…

常见前端面试之VUE面试题汇总十

28. Vuex 和 localStorage 的区别 (1)最重要的区别 vuex 存储在内存中 localstorage 则以文件的方式存储在本地,只能存储字符串类型的 数据,存储对象需要 JSON 的 stringify 和 parse 方法进行处理。 读 取内存比读取硬盘速度要…

LVGL学习 stm32f407-board-lvgl v8.3移植

LVGL学习 stm32f407-board-lvglv8.3移植 移植过程有问题,请参考正点原子的教程或者视频 硬件平台 STM32F407ZGT6核心板3.2寸屏幕 LVGL LVGL(Light and Versatile Graphics Library)是一个免费的开源图形库,提供创建具有易 于…

知识学爆——日常开发中的疑问

1.为什么说刷新页面vuex的数据会丢失 刷新页面vuex的数据会丢失属于正常现象,因为JS的数据都是保存在浏览器的堆栈内存里面的,刷新浏览器页面,以前堆栈申请的内存被释放,这就是浏览器的运行机制,那么堆栈里的数据自然就…

用NeRFMeshing精确提取NeRF网络中的3D网格

准确的 3D 场景和对象重建对于机器人、摄影测量和 AR/VR 等各种应用至关重要。 NeRF 在合成新颖视图方面取得了成功,但在准确表示底层几何方面存在不足。 推荐:用 NSDT编辑器 快速搭建可编程3D场景 我们已经看到了最新的进展,例如 NVIDIA 的…

解析代理IP在跨境电商和社媒营销中的关键作用

跨境电商和社媒营销领域的从业者深知,代理IP的价值愈发凸显。在推广营销的过程中,频繁遇到因IP关联而封禁账号的情况,或因使用不安全IP而导致异常问题。 这些问题促使人们开始高度重视代理IP的作用。但实际上,代理IP究竟是何物&a…

从C语言到C++_35(异常)C++异常的使用+异常体系+异常优缺点

目录 1. 异常的基本使用 1.1 异常的概念 1.2 异常的抛出和匹配原则 1.3 函数调用链中异常栈展开匹配原则 1.4 异常的重新抛出 1.5 异常的安全问题 1.6 C98和C11的异常规范 2. 自定义异常体系 2.1 异常继承体系 2.2 异常体系中的重新抛出 3. C标准库的异常体系 4. C…

每天一分享#读up有感#——云原生——持续学习

今日话题,云原生,看到两位大佬,就一起做下学习记录,爱了爱了。 江湖有缘,江湖见 https://blog.csdn.net/jks212454?typeblog 时间周期 第一篇文章:2021.04.17 粗略算,大佬不到2年就十万了…

YOLO目标检测——水果蔬菜数据集下载分享

水果蔬菜数据集共同90000图片,131类别分别存放在不同文件中,可应用于果蔬分类和种类识别等等 数据集点击下载:YOLO水果蔬菜数据集90000图片131类别.rar

【Linux的成长史】Linux的发展史

🎬 博客主页:博主链接 🎥 本文由 M malloc 原创,首发于 CSDN🙉 🎄 学习专栏推荐:LeetCode刷题集 数据库专栏 初阶数据结构 🏅 欢迎点赞 👍 收藏 ⭐留言 📝 如…

有哪些CAD转低版本软件?教你版本转换方法

当不同的人使用不同版本的CAD软件时,可能会出现不兼容的情况。例如,我们可能在使用较新版本的CAD软件,但是其他人可能仍在使用较早版本的软件。在这种情况下,就需要将您的CAD文件转换为较早的版本,也就是低版本&#x…

RT_Thread内核机制学习(一)

ARM架构及汇编 ARM芯片属于精简指令集计算机(RISC:Reduced Instruction Set Computer),它所使用的指令比较简单,有如下特点: 对内存只有读、写指令。对于数据的运算实在CPU内部实现。使用RISC指令的CPU复杂…

0基础学习VR全景平台篇 第92篇:智慧景区-智慧景区常见问题

Q:怎么编辑景区里面各个景点的介绍和推荐该景点A:在下方素材栏中该景点(素材)的右上角选择【编辑场景】里面就可以在场景介绍中编辑该场景的介绍并且在该选项中可以将此场景设置为推荐景点。 Q:景区项目可不可以离线浏…