- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章centos6.5 编译安装lamp以及相关错误的解决方法由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
1、准备工作 1、安装编译工具gcc、gcc-c++ 注意解决依赖关系,推荐使用yum安装,若不能联网可使用安装光盘做为yum源—— 。
1)编辑yum配置文件: #mount /dev/cdrom /mnt/cdrom #vi /etc/yum.repos.d/CentOS-Media.repo [c5-media] name=CentOS-$releasever- Media baseurl=file:///mnt/cdrom * 修改为光盘挂载点 file:///media/cdrom/ file:///media/cdrecorder/ gpgcheck=1 enabled=1 * 改为1意为启用 gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-5 2)剪切/etc/yum.repos.d/CentOS-Base.repo #mv /etc/yum.repos.d/CentOS-Base.repo /backup 3)依次安装gcc、gcc-c++ # yum -y install gcc # yum -y install gcc-c++ 2、关闭系统RPM安装包的Apache、MySQL的服务 关闭启动的服务httpd、mysqld #service httpd stop #service mysqld stop 确定rpm包安装的httpd和mysqld不能开机自启动 chkconfig --level 2345 httpd(mysqld) off 3、关闭SELinux,允许防火墙80端口访问 使用setup 关闭防火墙和SElinux 1)关闭SELinux #vi /etc/selinux/config SELINUX=disabled * 若安装时没有禁用SELinux ,将enforcing改为disabled 修改后需重新启动Linux方可生效! 2)关闭防火墙Netfilter/iptables 因尚未做防火墙讲解,直接简单的关闭所有防火墙设置: #iptables -F * 如果没有禁用防火墙,默认80端口禁止访问 iptables -Z iptables -X 4、关闭不必要自启动服务 # ntsysv 以下列出服务可保持自启动,未列出的服务都可以关闭: atd crond # atd、crond计划任务 irqbalance microcode_ctl # 系统irq端口调用,系统服务 network #网络设置 sendmail #邮件 sshd #远程管理 syslog #系统日志 5、拷贝源码包,解包解压缩 建议将LAMP环境安装源码包统一存放在一个目录下,如/lamp 可编写个批量处理脚本,一次性把所有.tar.gz的安装包解包解压缩 # vi tar.sh cd /lamp /bin/ls*.tar.gz > ls.list /bin/ls*.tgz >> ls.list forTAR in `cat ls.list` // 注意俩点 tab上面的丶 do /bin/tar -zxf $TAR done /bin/rmls.list 6、查看确认磁盘空间未满 df-h * 若/分区已满,可以移动安装包到其他分区或删除其他无用文件 cd 如何确定报错: 1)安装过程停止 2)停止后,一页界面中出现error或者warning 如何确定安装成功: 进入安装目录,确认安装程序出现,就是成功 2、编译安装 * 每个源码包配置编译安装完成后,确认安装目录下是否生成安装文件 make clean # 安装libxml2 Libxml2是一个xml c语言版的解析器,本来是为Gnome项目开发的工具,是一个基于MIT License的免费开源软件。它除了支持c语言版以外,还支持c++、PHP、Pascal、Ruby、Tcl等语言的绑定,能在Windows、Linux、Solaris、MacOsX等平台上运行。功能还是相当强大的,相信满足一般用户需求没有任何问题。 libxml是一个用来解析XML文档的函数库。它用C语言写成, 并且能为多种语言所调用,例如C语言,C++,XSH。C#, Python,Kylix/Delphi,Ruby,和PHP等。Perl中也可以使用XML::LibXML模块。它最初是为GNOME开发的项目,但现在可以用在各种各样的方面。libXML 代码可移植性非常好,因为它基于标准的ANSI C库, 并采用MIT许可证。 #yum install -y libxml2-devel 如果报错,安装此包后再尝试安装 yum -y installpython-devel 必须有 cd /lamp/libxml2-2.9.1 ./configure --prefix=/usr/local/libxml2/ make make install # 安装libmcrypt libmcrypt是加密算法扩展库。支持DES, 3DES, RIJNDAEL,Twofish, IDEA, GOST, CAST-256, ARCFOUR, SERPENT, SAFER+等算法。 cd /lamp/libmcrypt-2.5.8 ./configure --prefix=/usr/local/libmcrypt/ make make install * 需调用gcc-c++编译器,未安装会报错 # 安装libltdl,也在libmcrypt源码目录中,非新软件 cd /lamp/libmcrypt-2.5.8/libltdl ./configure --enable-ltdl-install make make install # 安装mhash Mhash是基于离散数学原理的不可逆向的php加密方式扩展库,其在默认情况下不开启。mhash的可以用于创建校验数值,消息摘要,消息认证码,以及无需原文的关键信息保存(如密码)等。 cd /lamp/mhash-0.9.9.9 ./configure make make install # 安装mcrypt mcrypt 是 php 里面重要的加密支持扩展库。Mcrypt库支持20多种加密算法和8种加密模式 cd /lamp/mcrypt-2.6.8 LD_LIBRARY_PATH=/usr/local/libmcrypt/lib:/usr/local/lib \ ./configure--with-libmcrypt-prefix=/usr/local/libmcrypt 反斜杠\表示一条命令 没打完换行了 #以上为一条命令。LD_LIBRARY_PATH用于指定libmcrypt和mhash的库的位置。 --with-libmcrypt-prefix用于指定libmcrypt软件位置 make make install #mcrypt没有安装完成,这是php的模块,需要等php安装完成之后,再继续安装 # 安装zlib zlib是提供数据压缩用的函式库,由Jean-loup Gailly与Mark Adler所开发,初版0.9版在1995年5月1日发表。zlib使用DEFLATE算法,最初是为libpng函式库所写的,后来普遍为许多软件所使用。此函式库为自由软件,使用zlib授权 cd /lamp/zlib-1.2.3 ./configure make make install >> /root/zlib.log * zlib指定安装目录可能造成libpng安装失败,故不指定,为卸载方便,建议make install执行结果输出到安装日志文件,便于日后卸载 # 安装libpng libpng 软件包包含 libpng 库.这些库被其他程式用于解码png图片 cd /lamp/libpng-1.2.31 ./configure --prefix=/usr/local/libpng make make install # 安装jpeg6 用于解码.jpg和.jpeg图片 mkdir /usr/local/jpeg6 mkdir /usr/local/jpeg6/bin mkdir /usr/local/jpeg6/lib mkdir /usr/local/jpeg6/include mkdir -p /usr/local/jpeg6/man/man1 #目录必须手工建立 cd /lamp/jpeg-6b ./configure --prefix=/usr/local/jpeg6/--enable-shared --enable-static make make install * --enable-shared与--enable-static参数分别为建立共享库和静态库使用的libtool # 安装freetype FreeType库是一个完全免费(开源)的、高质量的且可移植的字体引擎,它提供统一的接口来访问多种字体格式文件,包括TrueType,OpenType, Type1, CID, CFF, Windows FON/FNT, X11 PCF等。支持单色位图、反走样位图的渲染。FreeType库是高度模块化的程序库,虽然它是使用ANSI C开发,但是采用面向对象的思想,因此,FreeType的用户可以灵活地对它进行裁剪。 cd /lamp/freetype-2.3.5 ./configure--prefix=/usr/local/freetype/ make make install # 安装GD库 GD库,是php处理图形的扩展库,GD库提供了一系列用来处理图片的API,使用GD库可以处理图片,或者生成图片。 在网站上GD库通常用来生成缩略图,或者用来对图片加水印,或者用来生成汉字验证码,或者对网站数据生成报表等。 mkdir/usr/local/gd2 cd /lamp/gd-2.0.35 * png错误,修改方法: vi gd_png.c 把 #include “png.h” 替换为 #include"/usr/local/libpng/include/png.h" ./configure--prefix=/usr/local/gd2/ --with-jpeg=/usr/local/jpeg6/--with-freetype=/usr/local/freetype/ --with-png=/usr/local/libpng/ make make install * 若前面配置zlib时没有指定安装目录,gd配置时不要添加--with-zlib=/usr/local/zlib/参数 # 安装Apache configure: error: Bundled APR requested but not found at ./srclib/.Download and unpack the corresponding apr and apr-util packages to ./srclib/. #如果报错,则: tar zxvf apr-1.4.6.tar.gz tar zxvf apr-util-1.4.1.tar.gz cp -r /lamp/apr-1.4.6 /lamp/httpd-2.4.7/srclib/apr cp -r /lamp/apr-util-1.4.1 /lamp/httpd-2.4.7/srclib/apr-util #解压apr和apr-util,复制并取消版本号 configure: error: pcre-config for libpcre not found. PCRE is requiredand available from #如果报错,则: tarzxvf pcre-8.34.tar.gz cdpcre-8.34 ./configure&& make && make install checking whether to enable mod_ssl... configure: error: mod_ssl has beenrequested but can not be built due to prerequisite failures #如果报错,则: yum install openssl-devel 安装apache cd /lamp/httpd-2.4.7 ./configure --prefix=/usr/local/apache2/--sysconfdir=/usr/local/apache2/etc/ --with-included-apr --enable-so--enable-deflate=shared --enable-expires=shared --enable-rewrite=shared make makeinstall * 若前面配置zlib时没有指定安装目录,Apache配置时不要添加--with-z=/usr/local/zlib/参数 ****************************************************************** 启动Apache测试: /usr/local/apache2/bin/apachectl start ps–aux | grep httpd netstat–tlun | grep :80 * 若启动时提示/usr/local/apache2/modules/mod_deflate.so无权限,可关闭SELinux或者执行命令chcon -t texrel_shlib_t/usr/local/apache2/modules/mod_deflate.so ,类似此类.so文件不能载入或没有权限的问题,都是SELinux问题,使用命令:“chcon -t texrel_shlib_t 文件名”即可解决,MySQL和Apache也可能有类似问题。 通过浏览器输入地址访问:http://Apache服务器地址,若显示“It works”即表明Apache正常工作 设置Apache系统引导时启动: echo "/usr/local/apache2/bin/apachectl start" >>/etc/rc.d/rc.local # 安装ncurses Ncurses 提供字符终端处理库,包括面板和菜单。它提供了一套控制光标,建立窗口,改变前景背景颜色以及处理鼠标操作的函数。使用户在字符终端下编写应用程序时绕过了那些恼人的底层机制。简而言之,他是一个可以使应用程序直接控制终端屏幕显示的函数库。 1、 yum -y installncurses-devel 注:如果报错,包找不到,是*通配符没有识别,给文件名加双引号 “ncurses*” 2、源代码编译: cd /lamp/ncurses-5.9 ./configure --with-shared--without-debug --without-ada --enable-overwrite make make install * 若不安装ncurses编译MySQL时会报错 * --without-ada参数为设定不编译为ada绑定,因进入chroot环境不能使用ada ;--enable-overwrite参数为定义把头文件安装到/tools/include下而不是/tools/include/ncurses目录 * --with-shared 生成共享库 #安装cmake和bison mysql在5.5以后,不再使用./configure工具,进行编译安装。而使用cmake工具替代了./configure工具。cmake的具体用法参考文档cmake说明。 bison是一个自由软件,用于自动生成语法分析器程序,可用于所有常见的操作系统 yum -y install cmake yum -y install bison # 安装MySQL groupadd mysql useradd -g mysql mysql * 添加用户组mysql ,将mysql用户默认组设置为mysql用户组 cd /lamp/mysql-5.5.23 cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_UNIX_ADDR=/tmp/mysql.sock -DEXTRA_CHARSETS=all -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_MEMORY_STORAGE_ENGINE=1 -DWITH_READLINE=1 -DENABLED_LOCAL_INFILE=1 -DMYSQL_USER=mysql -DMYSQL_TCP_PORT=3306 -DCMAKE_INSTALL_PREFIX=/usr/local/mysql 安装位置 -DMYSQL_UNIX_ADDR=/tmp/mysql.sock 指定socket(套接字)文件位置 -DEXTRA_CHARSETS=all 扩展字符支持 -DDEFAULT_CHARSET=utf8 默认字符集 -DDEFAULT_COLLATION=utf8_general_ci 默认字符校对 -DWITH_MYISAM_STORAGE_ENGINE=1 安装myisam存储引擎 -DWITH_INNOBASE_STORAGE_ENGINE=1 安装innodb存储引擎 -DWITH_MEMORY_STORAGE_ENGINE=1 安装memory存储引擎 -DWITH_READLINE=1 支持readline库 -DENABLED_LOCAL_INFILE=1 启用加载本地数据 -DMYSQL_USER=mysql 指定mysql运行用户 -DMYSQL_TCP_PORT=3306 指定mysql端口 make make install make clean rm CMakeCache.txt #如果报错,清除缓存,请使用以上命令 cd /usr/local/mysql/ chown -R mysql . chgrp-R mysql . #修改mysql目录权限 /usr/local/mysql/scripts/mysql_install_db--user=mysql #创建数据库授权表,初始化数据库 chown-R root . chown -R mysql data #修改mysql目录权限 cpsupport-files/my-medium.cnf /etc/my.cnf #复制mysql配置文件 /usr/local/mysql/scripts/mysql_install_db--user=mysql 启动MySQL服务: 1.用原本源代码的方式去使用和启动mysql /usr/local/mysql/bin/mysqld_safe--user=mysql & &符号后台运行 2.重启以后还要生效: vi/etc/rc.local /usr/local/mysql/bin/mysqld_safe--user=mysql & 3.设定mysql密码 /usr/local/mysql/bin/mysqladmin-uroot password lonly 清空历史命令 history -c * 给mysql用户root加密码123 * 注意密码不能写成 “123” /usr/local/mysql/bin/mysql -u root -p mysql>showdatabases; mysql>usetest; mysql>showtables; mysql>\s #查看字符集是否改为utf8 * 进入mysql以后用set来改密码 mysql> exit * 登录MySQL客户端控制台设置指定root密码 # 安装PHP 编译前确保系统已经安装了libtool和libtool-ltdl软件包,安装: yum -y install “libtool*” yum -y install “libtool-ltdl*” vi /usr/local/gd2/include/gd_io.h typedef struct gdIOCtx { …… void(*data); #加入此句 } #php 5.4 的bug,检测gd库有问题,需要手工修改 cd/lamp/ php-5.4.25 ./configure--prefix=/usr/local/php/ --with-config-file-path=/usr/local/php/etc/--with-apxs2=/usr/local/apache2/bin/apxs --with-mysql=/usr/local/mysql/--with-libxml-dir=/usr/local/libxml2/ --with-jpeg-dir=/usr/local/jpeg6/--with-png-dir=/usr/local/libpng/ --with-freetype-dir=/usr/local/freetype/--with-gd=/usr/local/gd2/ --with-mcrypt=/usr/local/libmcrypt/ --with-mysqli=/usr/local/mysql/bin/mysql_config--enable-soap --enable-mbstring=all --enable-sockets --without-pear l 若前面配置zlib时没有指定安装目录,PHP配置时不要添加--with-zlib-dir=/usr/local/zlib/参数 选项: --with-config-file-path=/usr/local/php/etc/ 指定配置文件目录 --with-apxs2=/usr/local/apache2/bin/apxs 指定apache动态模块位置 --with-mysql=/usr/local/mysql/ 指定mysql位置 --with-libxml-dir=/usr/local/libxml2/ 指定libxml位置 --with-jpeg-dir=/usr/local/jpeg6/ 指定jpeg位置 --with-png-dir=/usr/local/libpng/ 指定libpng位置 --with-freetype-dir=/usr/local/freetype/ 指定freetype位置 --with-gd=/usr/local/gd2/ 指定gd位置 --with-mcrypt=/usr/local/libmcrypt/ 指定libmcrypt位置 --with-mysqli=/usr/local/mysql/bin/mysql_config 指定mysqli位置 --enable-soap 支持soap服务 --enable-mbstring=all 支持多字节,字符串 --enable-sockets 支持套接字 --without-pear 不安装pear(安装pear需要连接互联网。 PEAR是PHP扩展与应用库) make make install 生成php.ini cp/lamp/php-5.4.25/php.ini-production /usr/local/php/etc/php.ini 测试Apache与PHP的连通性,看Apache是否能解析php文件 vi /usr/local/apache2/etc/httpd.conf AddType application/x-httpd-php.php .phtml .phps (注意大小写) *.phtml为将.phps做为PHP源文件进行语法高亮显示 重启Apache服务:/usr/local/apache2/bin/apachectl stop /usr/local/apache2/bin/apachectl start *Apache无法启动,提示cannot restore segment protafter reloc: Permission denied错误,为SELinux问题,可关闭SELinux或者执行命令chcon -t texrel_shlib_t/usr/local/apache2/modules/libphp5.so 测试:vi /usr/local/apache2/htdocs/test.php <?php phpinfo(); ?> 通过浏览器输入地址访问:http://Apache服务器地址/test.php Rpm包安装的网页默认目录 /var/www/html/ * 有时第一次浏览器测试会失败,关闭浏览器重启再尝试即可,非编译错误 # 编译安装memcache Memcache是一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个统一的巨大的hash表,它能够用来存储各种格式的数据,包括图像、视频、文件以及数据库检索的结果等。简单的说就是将数据调用到内存中,然后从内存中读取,从而大大提高读取速度。 yum -y installzlib-devel cd memcache-3.0.8 /usr/local/php/bin/phpize ./configure--with-php-config=/usr/local/php/bin/php-config make && make install #编译安装mcrypt cd /lamp/php-5.4.25/ext/mcrypt/ /usr/local/php/bin/phpize ./configure --with-php-config=/usr/local/php/bin/php-config --with-mcrypt=/usr/local/libmcrypt/ make make install #php安装完成后,通过这些命令安装mcrypt模块 修改/usr/local/php/etc/php.ini extension_dir ="/usr/local/php/lib/php/extensions/no-debug-zts-20100525/" #打开注释,并修改 extension="memcache.so"; extension="mcrypt.so"; #添加 #重启apache,在phpinfo中可以找到这两个模块 #安装memcache源代码 首先安装依赖包libevent yum -y install “libevent*” #在CentOS 6.3第二张光盘中,请换盘 cd /lamp/memcached-1.4.17 ./configure--prefix=/usr/local/memcache make && make install useradd memcache #添加memcache用户,此用户不用登录,不设置密码 /usr/local/memcache/bin/memcached-umemcache & netstat an | grep :11211 telnet 192.168.10.1 11211 stats 写入自启动: vi/etc/rc.d/rc.local /usr/local/memcache/bin/memcached-umemcache & # 安装phpMyAdmin cp -r phpMyAdmin-4.1.4-all-languages/usr/local/apache2/htdocs/phpmyadmin cd/usr/local/apache2/htdocs/phpmyadmin cp config.sample.inc.phpconfig.inc.php vi config.inc.php $cfg['Servers'][$i]['auth_type']= 'cookie'; $cfg['Servers'][$i]['auth_type']= 'http'; * 设置auth_type为http ,即设置为HTTP身份认证模式 通过浏览器输入地址访问:http://Apache服务器地址/phpmyadmin/index.php 用户名为root ,密码为MySQL设置时指定的root密码(lampbrother) 安装过程中大多错误其实为输入错误,可以通过history命令查看历史记录检查。 GRANTALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '123' WITH GRANT OPTION; sql语句,不是linux命令 Grant all privileges on *.*to ‘root'@'%'identified by ‘123' with grant option 。
最后此篇关于centos6.5 编译安装lamp以及相关错误的解决方法的文章就讲到这里了,如果你想了解更多关于centos6.5 编译安装lamp以及相关错误的解决方法的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我正在使用 CentOS 6 机器。我尝试遵循以下指南: How to open port in centOS http://ask.xmodulo.com/open-port-firewall-ce
我正在为 CentOS 7 创建一个脚本,但我正在努力根据变量连接值,这与我工作的其他发行版不同。例如,在下面的代码中: DIR_BKP=/tmp/_bkp_local PATH_LOG=$DIR_B
我从以下位置下载了文件: https://github.com/christiangalsterer/httpbeat/releaseshttpbeat-4.0.0-x86_64.rpm 并尝试通过以
我想在我的 Centos 8 中使用命令 mkimage。 我尝试使用命令 dnf install uboot-tools 以 root 身份安装 uboot-tools 但这不可用。 谁能指导我如何
我有一个 Centos 服务器。 结果 $ cat /etc/centos-release CentOS Linux release 7.9.2009 (Core) 和 $ yum list i
我在CentOs7 上安装Gitlab 后遇到了麻烦。我第一次被重定向到管理员密码创建页面,在输入管理员用户密码后,服务器发送错误。 422 The change you requested was
因此,我正在尝试从我的一个运行 centos 的邮箱中发送电子邮件,并且我已经安装并打开了 sendmail,但是发送一封电子邮件实际上需要几分钟时间。电子邮件不是应该几乎是即时的吗? 这是我的/et
我正在尝试在虚拟 Centos 7 发行版上构建一些 C++ 库。由于我还没有发现这个操作系统看不到/usr/local/lib 或/usr/local/lib64 的原因,这些库安装在其他 linu
我正在尝试通过以下网址在我的服务器(centos 7.1 minimal)上安装 imagemagick: imagemagick installation steps 在第 1 步得到这个错误: L
当我尝试安装 rpmforge(我需要安装 phpmyadmin)时出现此错误,将不胜感激任何帮助! [root@plasticarmy ~]# yum http://pkgs.repoforge.o
我需要安装一个centos 5 repo 来在centos 7 机器上下载用于el5 的dhclient,以便在centos 5 机器上传输dhclient rpms。有可能的 ? 谢谢! 最佳答案
我正在开发一个可以在 CentOS 8 和 CentOS 7 系统上运行的程序。在其中,我使用 gethostbyname 将 DNS 名称解析为 IP 地址。 为了尝试使代码可移植,我正在使用以下命
我想在 CentOS7(或 CentOS6)上安装 cgal 模块。它需要 pgrouting 才能使用 PostGIS。 我一直用 CGAL Manual Installation 安装 cgal
我在 CentOS 平台上使用 R/RStudio。我需要查看二进制日志文件(/var/log/messages)是否包含有关图形设备绘图问题的更多信息,但我无法从 RStudio 中读取它。 我在社
我正在尝试在我的 CentOS 上本地安装 Kubernetes。我正在关注这个博客 http://containertutorials.com/get_started_kubernetes/inde
来自 http://kubernetes.io/docs/getting-started-guides/kubeadm/ CentOS Linux 版本 7.2.1511(核心) (1/4) 在主机上
使用tcpdump监控网络流量时,发现很多dns反向查询记录。 像这样: A_IP.55276 > DNS_IP.domain: 9247+ PTR?查询 IP.in-addr.arpa。 (45)
我正在尝试在 CentOS 6.7 和 ./configure --prefix=$HOME/local 上安装 mutt运行良好,但在 make install步骤,我在下面遇到了这个错误,我不知道
如何在 CENTOS 中删除所有以 *0x0.jpg 结尾的文件?我需要删除嵌套在文件夹和子文件夹中的多个文件 最佳答案 我假设你有一个外壳 - 试试 find /mydirectory -type
我需要检索安装在我的 Linux (Centos) 主机上的所有软件包的软件包版本。 rpm -qa 给了我所有已安装软件包的列表。 我知道 rpm -qi "package name"给了我包信息。
我是一名优秀的程序员,十分优秀!