Linux下MySQL 5.5.8 源码编译安装记录分享

Linux下MySQL 5.5.8 源码编译安装记录分享,需要的朋友可以参考下。

系统:Ubuntu 10.10
mysql源码文件:mysql-5.5.8.tar.gz
安装所需工具:cmake, GNU make, gcc, Perl, libncurses5-dev, bison(可选), chkconfig
注:
1.官方2010-11-18的源码有几处bug,在编译之前参照官方的说明,进行了手动修改。

官方说明链接:http://lists.mysql.com/commits/126782
2.官方5.5版本参考手册:http://dev.mysql.com/doc/
汗了一下,3392页的参考手册!
=>工具安装:
1. cmake
—-没有自己编译安装cmake
—-shell:~$ sudo apt-get install cmake
—-版本:2.8.2
2. GNU make
—-Ubuntu自带
—-版本:3.81
3.GCC
—-Ubuntu自带
—-版本:4.4.5(官方文档:必须3.2以上)
4.Perl
—-Ubuntu自带
—-版本:5.10.1
5.libncurses5-dev (ncurses-devel)
—-若差了这个包,在cmake的时候会报错。
—-Debian/Ubuntu上的包名是libncurses5-dev,RedHat和其他版本对应的是ncurses-devel
—-shell:~$ sudo apt-get install libncurses5-dev
—-报错信息
——————www.linuxidc.com—————
— MySQL 5.5.8
— Could NOT find Curses (missing: CURSES_LIBRARY CURSES_INCLUDE_PATH)
CMake Error at cmake/readline.cmake:82 (MESSAGE):
Curses library not found. Please install appropriate package,

remove CMakeCache.txt and rerun cmake.On Debian/Ubuntu , package name is libncurses5-dev ,
on RedHat and derivates it is ncurses-devel.
Call Stack (most recent call first):
cmake/readline.cmake:126 (FIND_CURSES)
cmake/readline.cmake:216 (MYSQL_USE_BUNDLED_LIBEDIT)
CMakeLists.txt:256 (MYSQL_CHECK_READLINE)

— Configuring incomplete, errors occurred!
———————————
6. bison
—-shell:~$ sudo apt-get install bison
—-可选。没有这个工具,在make的时候报出警告。
—-警告记录:
———————————

Warning: Bison executables not found in PATH
———————————
7.chkconfig
—-后面配置mysql服务自启动的时候需要。
—-shell:~$ sudo apt-get install chkconfig
=>mysql安装:
1.解压源代码文件
—-shell定位到源代码文件所在目录
—-解压
shell:~$ tar zxvf mysql-5.5.8.tar.gz
2.cmake操作
—-shell定位到解压出的源代码文件夹目录(文件夹:mysql-5.5.8)
—-cmake执行:
———————————
shell:~$ cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql
-DMYSQL_DATADIR=/home/system_username/Programming/mysql/mysqldata
-DSYSCONFDIR=/etc
-DWITH_INNOBASE_STORAGE_ENGINE=1
-DWITH_ARCHIVE_STORAGE_ENGINE=1
-DWITH_BLACKHOLE_STORAGE_ENGINE=1
-DWITH_FEDERATED_STORAGE_ENGINE=1
-DWITH_PARTITION_STORAGE_ENGINE=1
-DMYSQL_UNIX_ADDR=/tmp/mysqld.sock
-DMYSQL_TCP_PORT=3306
-DENABLED_LOCAL_INFILE=1
-DEXTRA_CHARSETS=all
-DDEFAULT_CHARSET=utf8
-DDEFAULT_COLLATION=utf8-general_ci
-DMYSQL_USER=mysql
注:没有换行。官方文档上,cmake 命令后面加个点不懂什么意思。在这里加上命令执行不了
———————————
源代码配置选项说明:
//mysql安装的主目录,5.5.8版本默认为/usr/local/mysql,所以可以不添加
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql

//mysql数据保存的路径,自定义
-DMYSQL_DATADIR=/home/system_username/mysql/mysqldata

//mysql配置文件地址——The default my.cnf option file directory
-DSYSCONFDIR=/etc

//Compile storage engine xxx statically into server
/*Storage engines are built as plugins. You can build a plugin as a static module (compiled into the server)
*or a dynamic module (built as a dynamic library that must be installed into the server using the INSTALL
*PLUGIN statement or the –plugin-load option before it can be used). Some plugins might not support static
*or dynamic building.
*/
-DWITH_INNOBASE_STORAGE_ENGINE=1
-DWITH_ARCHIVE_STORAGE_ENGINE=1
-DWITH_BLACKHOLE_STORAGE_ENGINE=1
-DWITH_FEDERATED_STORAGE_ENGINE=1
-DWITH_PARTITION_STORAGE_ENGINE=1

//Unix socket file
/*
*The Unix socket file path on which the server listens for socket connections. This must be an absolute path
*name. The default is /tmp/mysql.sock
*/
-DMYSQL_UNIX_ADDR=/tmp/mysqld.sock

//数据库服务器TCP/IP连接的监听端口,默认为3306
-DMYSQL_TCP_PORT=3306

//Whether to enable LOCAL capability in the client library for LOAD DATA INFILE
//默认为关闭,这里开启
-DENABLED_LOCAL_INFILE=1

//数据库编码设置
-DEXTRA_CHARSETS=all
-DDEFAULT_CHARSET=utf8
-DDEFAULT_COLLATION=utf8-general_ci
3.编译和安装
—-shell定位到源代码文件夹目录
—-执行:(编译用了大概20分钟)
shell:~$ make
shell:~$ make install

4.后续配置
—-进入mysql安装目录下的脚本目录
shell:~$ cd /usr/local/mysql/scripts
—-利用mysql_install_db脚本生成新的MySQL 授权表
./mysql_install_db –basedir=/usr/local/mysql –datadir=/home/system_username/Programming/mysql/mysqldata
–user=mysql
—-进入mysql安装目录下的支持文件目录
shell:~$ cd /usr/local/mysql/support-files
—-复制mysql配置文件
shell:~$ sudo cp my-medium.cnf /etc/my.cnf

—-复制服务文件并修改
shell:~$ sudo cp mysql.server mysqld
—-修改mysqld
basedir=/usr/local/mysql
datadir=/home/mysql
mv mysqld /etc/init.d/mysqld
—-启动服务
shell:~$ service mysqld start
—-关闭服务
shell:~$ service mysqld stop
———————————
service命令:
1. 用于管理Linux系统中服务的命令
2. 作用是去/etc/init.d目录下寻找相应的服务,进行开启和关闭等操作
3. 上述操作后,mysqld服务文件对应mysql.server文件
———————————
—-添加服务到自启动项
shell:~$ sudo chkconfig –level 3 mysqld on

—-设置软连接使mysql, mysqldump, mysqladmin这三个命令能在shell中直接运行
shell:~$ sudo ln -s /usr/local/mysql/bin/mysql /usr/bin
shell:~$ sudo ln -s /usr/local/mysql/bin/mysqldump /usr/bin
shell:~$ sudo ln -s /usr/local/mysql/bin/mysqladmin /usr/bin
———————————
=>mysql数据库中文乱码解决 :
1. 乱码分析
—-从终端shell进入mysql
shell:~$ mysql
…………
…………
mysql> show variables like ‘%character%’
—-得到以下数据库编码信息表:
+———————————– +——————————————-+
| Variable_name | Value |
+————————————+——————————————-+
| character_set_client | utf8 |
| character_set_connection | utf8 |
| character_set_database | latin1 |
| character_set_filesystem | binary |
| character_set_results | utf8 |
| character_set_server | latin1 |
| character_set_system | utf8 |
| character_sets_dir | /usr/local/mysql/share/charsets/ |
+———————————— +——————————————-+
可以看出character_set_database ,character_set_server 的编码还是默认的latin1。
不知道为什么,之前DEFAULT_CHARSET设置成为utf8的,好像没起作用。查看官方文档
发现,character_set_database不支持配置文件(/etc/my.cnf)变量设置,
但是character_set_server 支持配置文件变量设置。

2. 解决办法
—-打开配置文件
shell:~$ sudo gedit /etc/my.cnf
然后在[mysqld]配置选项下添加
character-set-server = utf8
—-然后进入mysql
执行:
mysql> show variables like ‘%character%’
结果:character_set_database ,character_set_server两项都变为utf8了
—-测试:
往数据库表中插入中文字段,中文就正常显示了。

注:1.用5.1版本的时候如下方法是可以解决中文编码问题的
—-在配置文件[mysqld]和[client]节下分别添加: default-character-set = utf8
2.不知到是不是手动编译的原因,在5.5.8中配置文件中用上述方法会造成数据库服务无法启动。
—-错误日志如下:( datadir/username.err为错误日志文件)
—————————————————-
mysqld_safe mysqld from pid file /home/cyberwym/Programming/mysql/mysqldata/cyberwym.pid ended
………..
………..
[ERROR] /usr/local/mysql/bin/mysqld: unknown variable ‘default-character-set=utf8’
[ERROR] Aborting
—————————————————-
—-这样会造成pid文件(datadir/username.pid)无法更新
—-在配置文件[mysqld]和[client]节下分别去掉: default-character-set = utf8 后,数据库服务就启动正常了

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/437514.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月7日 16:58:56
下一篇 2025年11月7日 17:04:05

相关推荐

  • Go HTTP 处理程序中依赖注入的优雅实践:使用闭包传递类型

    本文探讨了在 Go HTTP 处理程序中有效传递数据库连接等依赖的方法。通过引入闭包(closure)模式,我们可以将共享资源(如 *sql.DB)注入到 HTTP 处理函数中,从而避免使用全局变量,提高代码的模块化、可测试性和可维护性。教程将详细展示如何修改处理函数以接受依赖并返回 http.Ha…

    2025年12月16日
    000
  • Golang如何实现简单的论坛功能

    答案:使用Golang标准库net/http和html/template,结合SQLite数据库,可实现简易论坛。1. 定义Post和Comment结构体;2. 用database/sql操作SQLite建表存储数据;3. 注册HTTP路由并用模板渲染页面;4. 实现发帖、查看、评论功能,注意SQL…

    2025年12月16日
    000
  • Go语言database/sql:动态获取SQL查询结果的列类型信息

    本教程将深入探讨go语言标准库`database/sql`如何动态获取sql查询结果的列类型信息。通过`rows.columntypes()`方法,开发者可以在不预知数据库表结构的情况下,获取列名、数据库原生类型及go语言扫描类型等元数据,从而实现灵活的数据处理和映射,尤其适用于构建通用数据处理层或…

    2025年12月16日
    000
  • Go 中 GOMAXPROCS 的默认值及设置详解

    本文旨在清晰阐述 Go 语言中 `GOMAXPROCS` 的概念、默认值及其作用。`GOMAXPROCS` 用于设置同时执行的最大 CPU 数量,直接影响 Go 程序的并发性能。从 Go 1.5 开始,默认值已更改为可用 CPU 核心数,但了解其历史沿革和手动设置方法对于优化程序性能至关重要。本文将…

    2025年12月16日
    000
  • Golang RPC服务并发请求优化

    Go的RPC服务在高并发下需优化连接复用、序列化、超时控制等;通过长连接、Protobuf替代gob、限流熔断、异步处理及连接池可显著提升性能。 Go语言的RPC服务在高并发场景下表现良好,但若不加优化,容易出现性能瓶颈。核心问题通常集中在连接管理、序列化效率、资源竞争和超时控制等方面。合理调整这些…

    2025年12月16日
    000
  • 将数据库查询结果转换为 Golang 中的 Map 列表

    本文介绍了如何将数据库查询结果转换为 Golang 中的 []map[string]interface{} 类型,以便更灵活地处理数据。虽然使用结构体通常更高效,但在某些场景下,使用 Map 列表可以提供更大的通用性。本文将展示如何使用 sqlx 库简化转换过程,并探讨使用结构体和 Map 的优缺点…

    2025年12月16日
    000
  • 使用Go语言高效读取大型文件末尾内容的教程

    本教程详细介绍了如何使用go语言高效地读取大型文件的最后n行内容,而无需将整个文件加载到内存中。文章通过利用`os.file.seek`和`os.file.stat`函数,实现从文件末尾向后逐字节读取,并构建了一个完整的示例,演示了如何每隔10秒读取日志文件的最后两行,适用于日志监控等场景。 在处理…

    2025年12月16日
    000
  • 如何在 Go 程序中设置 ulimit -n

    本文介绍了如何在 Go 程序中通过 `syscall` 包来设置 `ulimit -n`,即进程可以打开的最大文件描述符数量。文章将详细讲解如何使用 `Getrlimit` 和 `Setrlimit` 函数,并提供示例代码,同时解释了可能遇到的 “invalid argument&#82…

    2025年12月16日
    000
  • 深入理解与调试 mDNS、Bonjour 和 Avahi 服务

    本文将探讨 mdns、bonjour 和 avahi 服务发现的调试方法。由于 mdns 不支持传统 dns 区域传输,我们将介绍通过主动查询、利用特定守护进程(如 avahi 和 mdnsresponder)的日志和状态转储功能,以及使用网络流量分析工具(如 wireshark 和 tcpdump…

    2025年12月16日
    000
  • Go与C++互操作:使用SWIG处理std::string参数的现代化实践

    本文详细阐述了如何利用swig在go语言与c++++之间高效地传递`std::string`参数。通过采用go 1.3.3及swig 3.0.2及更高版本提供的现代化方法,特别是借助`go build`的自动化能力,并结合`const std::string&`的规范使用,可以显著简化go与…

    2025年12月16日
    000
  • 将数据库查询结果转换为Go中的Map:实用指南

    本文旨在指导开发者如何将数据库查询结果转换为Go语言中的[]map[string]interface{}类型,以便更灵活地处理数据。虽然使用结构体通常更高效,但在某些场景下,动态地将数据映射到Map中可能更为方便。本文将介绍如何使用标准库以及第三方库sqlx来实现这一目标,并探讨各自的优缺点。 在G…

    2025年12月16日
    000
  • 将数据库查询结果转换为Go中的Map切片

    本文介绍了如何将数据库查询结果转换为Go语言中的`[]map[string]interface{}`类型,以便于处理动态查询结果。虽然使用`interface{}`可能导致类型断言的需要,但对于处理未知结构的查询结果,它提供了一种灵活的解决方案。本文将展示如何使用标准库和第三方库`sqlx`来实现这…

    2025年12月16日
    000
  • 在 Go 程序中设置 ulimit -n

    本文介绍了如何在 Go 程序中设置 `ulimit -n`,即进程可以打开的最大文件描述符数量。通过 `syscall` 包提供的 `Getrlimit` 和 `Setrlimit` 函数,我们可以查询和修改进程的资源限制。文章提供了一个示例程序,演示了如何获取和设置 `RLIMIT_NOFILE`…

    2025年12月16日
    000
  • 如何在Golang中实现跨平台Web服务

    Go语言通过内置HTTP库和多平台编译支持实现跨平台Web服务,示例代码展示基础服务器返回操作系统名称;关键在于避免平台相关依赖,使用filepath处理路径,避免调用系统命令,并选用纯Go第三方库;通过GOOS和GOARCH环境变量可交叉编译生成Linux、Windows、macOS等平台二进制文…

    2025年12月16日
    000
  • Golang如何安全释放资源避免错误

    Go语言需手动释放文件句柄等资源,defer语句可确保函数退出前调用关闭操作;2. defer注册时即对参数求值,循环中直接使用变量可能导致预期外行为。 在Go语言中,安全释放资源是编写健壮程序的关键。由于Go具备垃圾回收机制,很多人误以为不需要关心资源管理,但实际上像文件句柄、网络连接、数据库连接…

    2025年12月16日
    000
  • Golang如何实现基本的CRUD操作

    首先定义User结构体并使用map存储,实现createUser创建用户;通过getUser和getAllUsers读取单个或所有用户;updateUser根据ID更新信息;deleteUser删除用户;最后建议加锁保证并发安全。 在Go语言中实现基本的CRUD(创建、读取、更新、删除)操作,通常涉…

    2025年12月16日
    000
  • Golang如何处理并发数据库操作

    Go语言通过goroutine和channel实现并发,但操作数据库时需控制并发度以避免连接耗尽等问题。1. 使用database/sql的连接池管理并发,设置最大和闲置连接数;2. 通过SetMaxOpenConns、SetMaxIdleConns和SetConnMaxLifetime配置连接参数…

    2025年12月16日
    000
  • 解决Go语言连接MSSQL数据库的ODBC问题:一份实用指南

    本文旨在帮助Go开发者解决在使用ODBC连接MSSQL数据库时遇到的常见问题,特别是在不同操作系统下配置和使用ODBC驱动,以及处理编译和运行时错误。通过详细的步骤和示例,本文将指导你成功连接并操作MSSQL数据库。 前提条件 在开始之前,请确保你已经安装了以下组件: Go 语言环境 (Go 1.1…

    2025年12月16日
    000
  • 现代Go语言程序编译与运行指南

    本文旨在为go语言初学者提供一份现代化的程序编译与运行指南,纠正因遵循过时教程而产生的常见问题。我们将详细讲解go环境的正确配置,包括`path`环境变量的设置,以及如何使用go官方提供的`go`命令(如`go run`和`go build`)来高效地编译和执行go程序,同时提醒注意代码编写规范和官…

    2025年12月16日
    000
  • Go语言开发与部署:利用IntelliJ IDEA及其插件实现高效工作流

    本教程旨在指导go语言开发者如何利用intellij idea及其官方go插件,构建一个集开发、调试与自动化部署于一体的高效工作流。文章将详细介绍intellij idea的安装、go插件的配置,并重点阐述如何设置远程部署与文件自动上传功能,以实现类似于pycharm的便捷开发体验。 引言:Go语言…

    2025年12月16日
    000

发表回复

登录后才能评论
关注微信