编译安装mysql(Ubuntu10 64位)_MySQL
Ubuntu
bitsCN.com选用较好的编译器和较好的编译器选项,这样应用可提高性能10-30%,这个对大多数程序都非常重要
Mysql的编译,不同的版本具体的配置方式是有差别的
旧版的配置形式参考
这个形式主要是使用configure,具体参考
http://www.cnblogs.com/hemhem/archive/2011/03/14/2087481.html
http://blog.csdn.net/bing19880122/article/details/5830650
http://flyingdutchman.iteye.com/blog/1901149
MySQL cMake 新老参数对比及 cMake 配置及安装方法详解 http://waynerqiu.com/7/153.html
新版Cmake形式的配置
http://www.cmake.org/
http://www.cnblogs.com/2018/p/3091616.html
mysql配置
http://dev.mysql.com/doc/refman/5.6/en/source-configuration-options.html
http://dev.mysql.com/doc/refman/5.6/en/environment-variables.html
环境变量和CMAKE配置结合可以进行配置
如下是一个实例
#CMAKE_BUILD_TYPE Debug:-g Release:-O2 RelWithDebInfo:-O2 -g MinSizeRel:-Os
#WITH_EMBEDDED_SERVER Whether to build the libmysqld embedded server library.
#WITH_PARTITION_STORAGE_ENGINE 表分区
#-DWITH_ASAN=1 / #must gcc > 4.5 参考4.8.2
#DENABLE_DOWNLOADS google MOCK test
cmake . /
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql /
-DCMAKE_BUILD_TYPE=Release /
-DSYSCONFDIR=/etc /
-DINSTALL_SBINDIR=/usr/local/mysql/bin /
-DMYSQL_DATADIR=/usr/local/mysql/data /
-DMYSQL_UNIX_ADDR=/tmp/mysql.sock /
-DENABLED_LOCAL_INFILE=1 /
-DMYSQL_TCP_PORT=3306 /
-DDEFAULT_CHARSET=utf8 /
-DDEFAULT_COLLATION=utf8_general_ci /
-DWITH_EMBEDDED_SERVER=0 /
-DWITH_MYISAM_STORAGE_ENGINE=1 /
-DWITH_INNOBASE_STORAGE_ENGINE=1 /
-DWITH_PARTITION_STORAGE_ENGINE=1 /
-DWITH_ARCHIVE_STORAGE_ENGINE=0 /
-DWITH_BLACKHOLE_STORAGE_ENGINE=0 /
-DWITH_MEMORY_STORAGE_ENGINE=0 /
-DWITH_PERFSCHEMA_STORAGE_ENGINE=0 /
-DWITH_EXTRA_CHARSETS=none /
-DWITH_DEBUG=0 /
# -DWITH_ASAN=1 /
# -DENABLE_DOWNLOADS=0 /
#end of cmake
注意-DWITH_ASAN=1这个选项需要GCC的版本在4.5以上,而Ubuntu10上默认的GCC是4.4
GCC编译升级过程
http://ftp.tsukuba.wide.ad.jp/software/gcc/releases/gcc-4.8.2/gcc-4.8.2.tar.gz 从这下载GCC
使用如下的脚本可以进行升级
#!/bin/bash
# gcc version 4.4.3 (Ubuntu 4.4.3-4ubuntu5.1)
:
ftp://gcc.gnu.org/pub/gcc/infrastructure/
GNU Multiple Precision Library (GMP) version 4.3.2 (or later)
MPFR Library version 2.4.2 (or later)
MPC Library version 0.8.1 (or later)
EOF
gccver=4.8.2
gmpver=4.3.2
mpfrver=2.4.2
mpcver=0.8.1
# where you put the downloaded source packages
pkgdir=.
# where you will build gcc
rootdir=gcc-${gccver}
# where you want to install gcc
prefix=/opt/gcc-${gccver}
# the languages you want gcc to support
langs=c,c++
#0 unpack file
:
#Create a new directory on a disk with plenty of space and unpack the sources there:
mkdir -p ${rootdir}
tar xzf ${pkgdir}/gcc-${gccver}.tar.gz
tar xjf ${pkgdir}/gmp-${gmpver}.tar.bz2
tar xjf ${pkgdir}/mpfr-${mpfrver}.tar.bz2
tar xzf ${pkgdir}/mpc-${mpcver}.tar.gz
#Next, move the prerequisite sources into the gcc source directory:
mv gmp-${gmpver} ${rootdir}/gmp
mv mpfr-${mpfrver} ${rootdir}/mpfr
mv mpc-${mpcver} ${rootdir}/mpc
EOF
#两种方式的编译和安装
#1.1 build on source dir
pushd ${rootdir}
#make clean
#默认的gcc支持32/64的双编译 gcc.gnu.org/wiki/FAQ#gnu_stubs-32.h glibc-devel-32bit 或 --disable-multilib
./configure --prefix=${prefix} --enable-languages=${langs} --disable-multilib
make
make install
popd
#1.2 build on other dir
:
#Now create a build directory and change to it
mkdir -p objdir
cd objdir
#Now configure gcc:
mkdir -p ${prefix}
../${rootdir}/configure --prefix=${prefix} --enable-languages=${langs} --disable-multilib
#configure --prefix=/opt/gcc-4.8.2 --enable-languages=c,c++
#Now build gcc:
make
#Finally, install gcc:
make install
#fixincludes 目录没有拷贝的问题,估计是--disable-multilib
cd ..
EOF
###代码+编译文件 2.6G
#2 更改当前的默认 #具体可检索"更改Ubuntu gcc、g++默认编译器版本"
#修改默认gcc和g++为4.4的版本
sudo update-alternatives --remove-all gcc
sudo update-alternatives --remove-all g++
sudo update-alternatives --install /usr/bin/gcc gcc /opt/gcc-4.8.2/bin/gcc 40
sudo update-alternatives --install /usr/bin/g++ g++ /opt/gcc-4.8.2/bin/g++ 40
#配置默认的gcc和g++
sudo update-alternatives --config gcc
sudo update-alternatives --config g++
#3 系统的C++库覆盖
rm -f /usr/lib/libstdc++*
cp -f /opt/gcc-4.8.2/lib64/libstdc++.so.6.0.18 /usr/lib/.
cp -f /opt/gcc-4.8.2/lib64/libstdc++.so.6 /usr/lib/.
注意其中的--disable-multilib这个选项需要加上,因此默认的gcc是可以在64为平台上编译出32,64两种程序,因此编译版的gcc升级时就需要32位的头文件,如果没有安装的话,这个是无法编译的。
当然也有一些简化的方式,需要联网升级,如下的这个说明
http://www.qtcn.org/bbs/apps.php?q=diary&a=detail&did=1456&uid=139371
编译安装
此时就可以加上 -DWITH_ASAN=1 / 进行编译了
注意:为了提高性能,我们只需要编译需要的功能即可
成功后的安装,就非常简单了,类似如下的脚本过程
make install
#sudo cp -f my.cnf /etc/my.cnf
#sudo chmod 0444 /etc/my.cnf
sudo sh -c 'groupadd mysql'
sudo sh -c 'useradd -r -g mysql mysql'
sudo chown -R mysql /usr/local/mysql/data
sudo /usr/local/mysql/scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data
#sudo cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql
/usr/local/mysql/support-files/mysql.server start
login="/usr/local/mysql/bin/mysql -uroot -D mysql -e"
pass="/usr/local/mysql/bin/mysql -uroot -p123456 -D mysql -e"
${login} "update mysql.user set password=PASSWORD('123456') where user='root';"
${login} "flush privileges;"
详细的资料和脚本参考 http://pan.baidu.com/s/1Cc7cr
Gcc版本切换的脚本
由于新版的gcc的支持了C++11标准,默认要求差别较大,如果现有的工程需要低的版本的话,可以使用如下的形式对系统的gcc进行自动切换
#!/bin/bash
if [ $# = 1 ] ; then
#4.4 目前的Ubuntu10都是gcc 4.4
#修改默认gcc和g++
sudo update-alternatives --remove-all gcc
sudo update-alternatives --remove-all g++
sudo update-alternatives --install /usr/bin/gcc gcc /usr/bin/gcc-4.4 40
sudo update-alternatives --install /usr/bin/g++ g++ /usr/bin/g++-4.4 40
#配置默认的gcc和g++
sudo update-alternatives --config gcc
sudo update-alternatives --config g++
#系统的C++库覆盖 gcc 4.4
# rm -f /usr/lib/libstdc++*
# cp -f gcc4.4/libstdc++.so.6.0.13 /usr/lib/.
# ln -s /usr/lib/libstdc++.so.6.0.13 /usr/lib/libstdc++.so.6
else
#4.8
#gcc-4.8.2.tar.gz 安装到/opt
if [ -d /opt/gcc-4.8.2 ]; then
echo "gcc 4.8.2 installed"
else
tar xzf gcc-4.8.2.tar.gz -C /opt
fi
#修改默认gcc和g++
sudo update-alternatives --remove-all gcc
sudo update-alternatives --remove-all g++
sudo update-alternatives --install /usr/bin/gcc gcc /opt/gcc-4.8.2/bin/gcc 40
sudo update-alternatives --install /usr/bin/g++ g++ /opt/gcc-4.8.2/bin/g++ 40
#配置默认的gcc和g++
sudo update-alternatives --config gcc
sudo update-alternatives --config g++
#系统的C++库覆盖
# rm -f /usr/lib/libstdc++*
# cp -f /opt/gcc-4.8.2/lib64/libstdc++.so.6.0.18 /usr/lib/.
# cp -f /opt/gcc-4.8.2/lib64/libstdc++.so.6 /usr/lib/.
fi
#libstdc++.so.6 经试验选用高的libstdc++.so.6.0.18版本可以运行,具体都我们的应用有没有问题待验证
gcc -v
参考资料
这里有如上的相关资料和内容 http://pan.baidu.com/s/1Cc7cr
http://www.cnblogs.com/2018/p/3482263.html
http://www.cnblogs.com/2018/p/3464638.html
这两篇已经介绍了clang的安装和编译c++库的过程,下面会再讲讲mysql的clang编译安装过程
bitsCN.com
热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

MySQL在Web应用中的主要作用是存储和管理数据。1.MySQL高效处理用户信息、产品目录和交易记录等数据。2.通过SQL查询,开发者能从数据库提取信息生成动态内容。3.MySQL基于客户端-服务器模型工作,确保查询速度可接受。

Laravel 是一款 PHP 框架,用于轻松构建 Web 应用程序。它提供一系列强大的功能,包括:安装: 使用 Composer 全局安装 Laravel CLI,并在项目目录中创建应用程序。路由: 在 routes/web.php 中定义 URL 和处理函数之间的关系。视图: 在 resources/views 中创建视图以呈现应用程序的界面。数据库集成: 提供与 MySQL 等数据库的开箱即用集成,并使用迁移来创建和修改表。模型和控制器: 模型表示数据库实体,控制器处理 HTTP 请求。

MySQL和phpMyAdmin是强大的数据库管理工具。1)MySQL用于创建数据库和表、执行DML和SQL查询。2)phpMyAdmin提供直观界面进行数据库管理、表结构管理、数据操作和用户权限管理。

MySQL与其他编程语言相比,主要用于存储和管理数据,而其他语言如Python、Java、C 则用于逻辑处理和应用开发。 MySQL以其高性能、可扩展性和跨平台支持着称,适合数据管理需求,而其他语言在各自领域如数据分析、企业应用和系统编程中各有优势。

在开发一个小型应用时,我遇到了一个棘手的问题:需要快速集成一个轻量级的数据库操作库。尝试了多个库后,我发现它们要么功能过多,要么兼容性不佳。最终,我找到了minii/db,这是一个基于Yii2的简化版本,完美地解决了我的问题。

文章摘要:本文提供了详细分步说明,指导读者如何轻松安装 Laravel 框架。Laravel 是一个功能强大的 PHP 框架,它 упростил 和加快了 web 应用程序的开发过程。本教程涵盖了从系统要求到配置数据库和设置路由等各个方面的安装过程。通过遵循这些步骤,读者可以快速高效地为他们的 Laravel 项目打下坚实的基础。

MySQL的基本操作包括创建数据库、表格,及使用SQL进行数据的CRUD操作。1.创建数据库:CREATEDATABASEmy_first_db;2.创建表格:CREATETABLEbooks(idINTAUTO_INCREMENTPRIMARYKEY,titleVARCHAR(100)NOTNULL,authorVARCHAR(100)NOTNULL,published_yearINT);3.插入数据:INSERTINTObooks(title,author,published_year)VA

在使用Thelia开发电商网站时,我遇到了一个棘手的问题:MySQL模式设置不当,导致某些功能无法正常运行。经过一番探索,我找到了一个名为TheliaMySQLModesChecker的模块,它能够自动修复Thelia所需的MySQL模式,彻底解决了我的困扰。
