linux 线程编译 linux查看线程信息

大家好,关于linux 线程编译很多朋友都还不太明白,不过没关系,因为今天小编就来为大家分享关于linux查看线程信息的知识点,相信应该可以解决大家的一些困惑和问题,如果碰巧可以解决您的问题,还望关注下本站哦,希望对各位有所帮助!

如何编译Linux内核

内核配置完成,输入make命令即可开始编译内核。如果没有修改Makefile文件并指定ARCH和CROSS_COMPILE参数,则须在命令行中指定:

$ make ARCH=arm CROSS_COMPILE=arm-none-linux-gnueabi-

目前大多数主机都是多核处理器,为了加快编译进度,可以开启多线程编译,在make的时候加上“-jN”即可,N的值为处理器核心数目的2倍。例如对于I7 4核处理器,可将N设置为8:

$ make ARCH=arm CROSS_COMPILE=arm-none-linux-gnueabi--j8

采用多线程编译的优点是能加快编译进度,。具体可以参照ZLG《嵌入式Linux开发教程(下册)》第1章。

linux下安装mysql,求助大侠们

3. MySQL的安装

MySQL有两种安装方式:源码包安装和二进制包安装。这两种方式各有特色:二位制包安装不需编译,针对不同的平台有经

过优化编译的不同的二进制文件以及包格式,安装简单方便;源码包则必须先配置编译再安装,可以根据你所用的主机环境进行优化,选择最佳的配置值,安装定制

更灵活。下面分别介绍这两种安装方式。

3.1源码包方式安装

3.1.1在linux系统中添加运行Mysql的用户和组

/usr/sbin/groupadd mysql

/usr/sbin/useradd-d/var/lib/mysql-s/sbin/nologin-g mysql mysql

3.1.2下载最新稳定发行版(GA)的MySQL软件

访问MySQL网站下载最新稳定发行版的MySQL源码包。本文使用的是5.0.51版本,在linux系统下用下面的命令下载:

wget

3.1.3解压缩下载的源码包

首先建立一个工作目录(笔者建议的目录为/usr/local/src/mysql):

mkdir-p/usr/local/src/mysql

将下载的源码包移至工作目录:

mv mysql-5.0.51.tar.gz/usr/local/src/mysql

进入工作目录并用tar命令解压源码包:

cd/usr/local/src/mysql

tar zxvf mysql-5.0.51.tar.gz

命令执行结束后,当前工作目录下将生成一个新的子目录mysql-5.0.51,此目录下即为mysql的源码文件。

3.1.4配置Makefile文件

进入MySQL源码目录:

cd mysql-5.0.51

执行下面的命令可查看可配置选项:

./configure--help

本文使用的配置命令格式如下:

CC=gcc CFLAGS="-O3" CXX=gcc CXXFLAGS="-O3-felide-constructors

-fno-exceptions-fno-rtti"./configure

--prefix=/usr/local/mysql--enable-thread-safe-client--enable-assembler

--with-big-tables--with-client-ldflags=-all-static

--with-mysqld-ldflags=-all-static--with-charset=utf8

--with-collation=utf8_general_ci--with-extra-charsets=complex

配置选项说明:

CC:C编译器的名称(用于运行configure),本文示例为gcc

CFLAGS:C编译器的标志(用于运行configure),本文示例为-O3,指定优化级别为3

CXX:C++编译器的名称(用于运行configure),本文示例为gcc

CXXFLAGS:C++编译器的标志(用于运行configure)

--prefix:指定安装目录,本文示例为/usr/local/mysql

--localstatedir:指定默认数据库文件保存目录,默认为安装目录下的var目录

--enable-thread-safe-client:编译线程安全版的MySQL客户端库

--enable-assembler:使用一些字符函数的汇编版本

--with-client-ldflags:客户端链接参数,本文示例为指定静态编译mysql客户端

--with-mysqld-ldflags:服务器端链接参数,本文示例为指定静态编译mysql服务器

--with-big-tables:在32位平台上支持大于4G行的表

--with-charset:指定默认字符集。mysql默认使用latin1(cp1252)字符集,可以使用此选项更改。字符集可以是big5、

cp1251、cp1257、czech、danish、dec8、dos、euc_kr、gb2312、gbk、german1、hebrew、

hp8、hungarian、koi8_ru、koi8_ukr、latin1、latin2、sjis、swe7、tis620、ujis、usa7或

win1251ukr。

--with-collation:指定默认校对规则。mysql默认使用latin1_swedish_ci校对规则,可以使用此选项更改。

--with-extra-charsets:服务器需要支持的字符集,有三种可能的值:空格间隔的一系列字符集名;complex,包括不能动态装载的所有字符集;all,将所有字符集包括进二进制。本文示例为complex。

注意:要想更改字符集和校对规则,要同时使用--with-charset和--with-collation选项。校对规则必须是字符集的合法校对规则。(在mysql中使用SHOW COLLATION语句来确定每个字符集使用哪个校对规则)。

3.1.5编译源代码

执行下面的命令编译源代码:

make

3.1.6安装

执行下面的命令安装mysql到目标路径:

make install

3.1.7复制默认全局启动参数配置文件到/etc目录

码方式安装需要手动复制配置文件,配置模板位于源码树的support-files目录,有my-small.cnf、my-medium.cnf、

my-large.cnf、my-huge.cnf四个,选择跟你的环境相接近的一个复制到/etc目录,并做适当修改。关于mysql配置文件的详细信

息请参阅笔者的其它文章或是mysql官方文档。

本文示例选择my-medium.cnf,执行下面的命令将其复制到/etc目录:

cp./support-files/my-medium.cnf/etc/my.cnf

3.1.8初始化授权表

执行下面的命令初始化授权表:

./scripts/mysql_install_db--user=mysql

3.1.9更改mysql数据目录属主和权限

默认数据库文件保存目录为安装目录下的var目录,执行configure命令时可通过--localstatedir参数指定不同的目录,本文示例为默认位置。

chown-R mysql.mysql/usr/local/mysql/var

chmod-R 700/usr/local/mysql/var

3.1.10设置开机自启动服务控制脚本

执行下面的命令复制启动脚本到资源目录:

cp./support-files/mysql.server/etc/rc.d/init.d/mysqld

执行下面的命令增加mysqld服务控制脚本执行权限:

chmod+x/etc/rc.d/init.d/mysqld

执行下面的命令将mysqld服务加入到系统服务:

chkconfig--add mysqld

执行下面的命令检查mysqld服务是否已经生效:

chkconfig--list mysqld

命令输出类似下面的结果:

mysqld 0:off 1:off 2:on 3:on 4:on 5:on 6:off

表明mysqld服务已经生效,在2、3、4、5运行级别随系统启动而自动启动,以后可以使用service命令控制mysql的启动和停止。

启动mysqld服务:

service mysqld start

停止mysqld服务:

service mysqld stop

执行下面的命令关闭开机自启动:

chkconfig mysqld off

执行下面的命令可以改变开机自启动的运行级别为3、5:

chkconfig--level 35 mysqld on

3.1.11将mysql的bin目录加入PATH环境变量

编辑/etc/profile文件:

vi/etc/profile

在文件最后添加如下两行:

PATH=$PATH:/usr/local/mysql/bin

export PATH

执行下面的命令使所做的更改生效:

./etc/profile

3.2二进制包方式安装

3.2.1从安装媒体安装

Mysql二进制包已经包含在CentOS 5的安装媒体中,可以直接从安装媒体中安装下面三个rpm包:

mysql-5.0.22-2.1.0.1.i386.rpm

mysql-devel-5.0.22-2.1.0.1.i386.rpm

mysql-server-5.0.22-2.1.0.1.i386.rpm

不同的版本文件名有所不同,请注意区分。

执行下面的命令安装:

rpm-iUvh mysql-5.0.22-2.1.0.1.i386.rpm

rpm-iUvh mysql-devel-5.0.22-2.1.0.1.i386.rpm

rpm-iUvh mysql-server-5.0.22-2.1.0.1.i386.rpm

3.2.2通过yum安装

如果你安装的机器此时可以连接到互联网,笔者建议使用yum命令来简化安装过程:

yum install mysql-server mysql-devel mysql

yum将自动从centos的镜像站点查找你指明的软件的最新二进制包,并检查软件包依赖关系,安装软件的同时自动安装其依赖的软件包。

3.2.3从mysql网站下载最新稳定版本的二进制包安装

通过CentOS安装媒体或yum安装的二进制包版本会落后于mysql开发者网站发布的版本,可以从mysql网站下载安装最新稳定版本的mysql。

访问MySQL网站下

载最新稳定发行版的相应硬件平台的MySQL。本文使用的是Red Hat Enterprise Linux 5 RPM(x86)

5.0.45版本。需要下载Server、Client、Headers and Libraries、Share Libraries/Shared

compatibility libraries几个rpm包,其它为可选包,按需要选择。

在linux系统下用下面的命令下载:

wget

wget

wget

wget

wget

执行下面的命令安装:

rpm-iUvh MySQL-server-community-5.0.45-0.rhel5.i386.rpm

rpm-iUvh MySQL-client-community-5.0.45-0.rhel5.i386.rpm

rpm-iUvh MySQL-devel-community-5.0.45-0.rhel5.i386.rpm

rpm-iUvh MySQL-shared-community-5.0.45-0.rhel5.i386.rpm

rpm-iUvh MySQL-shared-compat-5.0.45-0.rhel5.i386.rpm

4. MySQL的配置

4.1目录结构

4.1.1源码包方式安装目录结构

源码包方式安装时通常是在3.1.4节中configure命令的--prefix选项指定的目录中建立如下的目录结构,特殊指定的目录除外:

./bin#mysql用户可执行文件目录

./include/mysql#mysql C头文件目录

./info#mysql信息文件目录

./lib/mysql#mysql库文件目录

./libexec#mysql后台daemon程序目录

./man#mysql联机帮助文档目录

./mysql-test#mysql测试程序目录

./share/mysql#mysql公用文件目录,包括字符集、配置文件模板、启动脚本、初始化SQL文件等

./sql-bench#mysql压力测试程序目录

/etc/my.cnf#mysql配置文件

/etc/rc.d/init.d/mysqld#mysqld服务启动脚本

4.1.2 RPM二进制包方式安装目录结构

二进制包方式安装时使用系统软件默认目录结构:

/usr/bin#mysql用户可执行文件目录

/usr/libexec#mysql后台daemon程序目录

/usr/lib/mysql#mysql库文件目录

/usr/lib64/mysql#如果为64系统,mysql 64位库文件目录

/usr/share/doc#mysql文档目录

/usr/share/info#mysql信息文件目录

/usr/share/man#mysql联机帮助文档目录

/usr/share/mysql#mysql字符集目录

/usr/include/mysql#mysql C头文件目录

/var/log#mysqld服务日志文件目录

/var/run/mysqld#mysqld服务运行状态目录

/var/lib/mysql#mysql数据文件目录

/etc/my.cnf#mysql配置文件

/etc/rc.d/init.d/mysqld#mysqld服务启动脚本

4.2配置文件

Linux

系统下,mysql的配置参数文件为my.cnf,一般按下面的顺序查找此文件:/etc目录、mysql安装目录、mysql数据目录。配置模板位于源

码树的support-files目录,有my-small.cnf、my-medium.cnf、my-large.cnf、my-huge.cnf四

个,关于mysql配置文件的详细信息请参阅笔者的其它文章或是mysql官方文档。

4.3启动mysqld服务

执行下面的命令启动mysql:

service mysqld start

4.3设置mysql帐号

mysql安装后默认生成两个帐号:一个是root,未设置密码,可以从本机登录到mysql;另一个是匿名帐号,无帐号名、无密码,可以从本机登录,未提供用户名的连接都将假定为此帐号。这样的设置存在着安全隐患,按下面的步骤进行更改。

以root帐号连接到mysql服务器:

mysql-u root

如果提示找不到mysql文件,请尝试使用绝对路径,如本文示例为:

/usr/local/mysql/bin/mysql-u root

命令成功执行后将进入到mysql命令提示符下:

mysql>

(以下命令均在mysql命令提示符下执行)

改变当前数据库为mysql:

use mysql

设置从本地主机登录的root帐号密码:

set password for root@localhost=password('your password');

或:

update user set password=password('your password') where user='root' and host='localhost';

删除匿名帐号:

delete from user where user='';

删除密码为空的帐号:

delete from user where password='';

删除允许非localhost主机登录的帐号:

delete from user where host<>'localhost';

执行下面的命令使更改生效:

flush privileges;

执行下面的命令退出mysql命令行:

quit

或:

/q

5.结束语

至此,Mysql基本安装完毕。希望本文能对初学者有所帮助。

QT Creator配置嵌入式Linux交叉编译环境

大四那年,我曾研究过如何在PC机上交叉编译出能在树莓派运行的ARM汇编程序。现在,我突发奇想,是否也能在QT Creator上配置交叉编译环境,以在嵌入式Linux上运行QT程序呢?本文将以全志V853芯片作为目标平台为例,详细介绍如何在QT Creator上配置交叉编译环境。对于其他目标平台,参数稍作修改即可。

**准备交叉编译器环境**

首先,利用全志V853开发板提供的Tina SDK包中的交叉编译器。假设Tina SDK包放置在当前用户目录下,目录名为tina-v853-open,则交叉编译器所在路径为~/.tina-v853-open/bin。接下来,将交叉编译器路径、编译器引用的库文件路径添加至环境变量。在~/.bashrc文件末尾,使用管理员权限编辑,加入以下两行代码。然后执行命令刷新环境变量。

验证交叉编译器环境是否配置好,输入特定命令,查看gcc版本,确保版本为8.3.0。

**编译QT源码**

编译目标是生成在目标平台可用的QT库以及相应的qmake。首先下载QT源码,解压至当前用户目录。接下来,修改qmake.conf文件,调整配置以适应目标平台。随后,新建目录存放编译后的QT库,配置编译选项,指定编译线程数,加快编译速度。最后,开始编译QT源码,并验证编译结果。

**配置QT Creator**

QT Creator是用于QT程序开发的IDE。若未安装,可通过相应途径获取。配置编译器时,打开QT Creator,选择“工具”->“选项”,在“编译器”一栏中添加GCC和G++编译器路径,指定名称。接着,配置交叉编译用的QT版本,通过添加qmake路径到“QT Versions”中。最后,配置Kits,设置编译器和QT版本,验证配置是否有效。

**验证测试**

新建C语言工程测试配置的交叉编译环境。在“项目”中设置环境变量,确保编译成功。通过编译后的文件指令集检查,确认程序的指令集与目标平台兼容,完成对交叉编译环境的验证。

阅读剩余
THE END