Home  >  Article  >  Backend Development  >  apache mysql php source code compilation and usage_PHP tutorial

apache mysql php source code compilation and usage_PHP tutorial

WBOY
WBOYOriginal
2016-07-21 15:19:22683browse

Linux version: ubuntu 12.04
Today I completed the configuration of php mysql and apache
Mainly source code configuration,
apache mainly version 2.4.2
php mainly version 5.3.11
mysql mainly It is version 5.1.62

I tried it several times a few days ago, but there was a software source conflict. I put two sources in the same source, and after modification, there were no major problems with the installation.
The overall situation is as follows.

The process I completed is as follows:
apache configuration:
./configure --prefix=/usr/local/apache/ --with-libxml2 -- enable-modules
=most --enable-mods-shared=all

Look at this apache classic example.
Add the latest version of libxml2 on ubuntu, and then everything is ok
make
make install
Then enter 127.0.0.1 and you can see it’s work!
mysql configuration:
cd mysql
sudo ./configure –prefix=/usr/local/mysql –with-mysqld-user=mysql
–with-extra-charsets=all –enable-thread -safe-client
Be careful in the ./configure configuration and pay attention to the prompts
I spent that ./configure in Xiaozhong, and then it went smoothly
make
make install
Because the configuration file needs to be copied to the etc directory
sudo cp /mypath/mysql /etc/my.cnf
[mysqld]# Set the default to INNODB table, support transactions: default-storage-engine= INNODB
# Set the default character set UTF-8:
character-set-server=utf8
collation-server=utf8_general_ci
default-character-set=utf8
# mysql startup user
user=mysql
[client]
default-character-set=utf8
In order to allow ordinary users to start mysql, grant the following permissions to the mysql directory
sudo chown -R mysql: mysql /usr/local /mysql
Then, switch to the mysql user and find that mysql is started
ps aux | grep mysqld
If there is /usr/local/mysql/bin/. . . It shows that mysql is started, and the mysql configuration is ok

in
Php configuration:
The most complicated configuration is PHP, the key is that there are too many modules

It takes a little time to configure and install Long, sometimes I think it’s a crash?

./configure --prefix=/usr/local/php
--with-apxs2=/usr/local/apache/bin/apxs
--with-mysql-dir=/ usr/local/mysql
--with-mysql-sock=/tmp/mysql.sock
--with-pdo-mysql=/usr/local/mysql
--with-mysqli=/usr /local/mysql/bin/mysql_config
--enable-mod-charset
--enable-bcmath
--with-bz2
--enable-calendar
--with-curl
--with-curlwrappers
--enable-exif
--enable-ftp
--with-gdbm
--with-gd=shared
--with-ttf
--enable-gd-native-ttf
--with-gettext
--with-gmp
--enable-mbstring=all
--enable-zend-multibyte
--with-ming=shared
--enable-sqlite-utf8
--enable-shmop
--enable-soap
--enable-sockets
--enable-sysvmsg
--enable-sysvsem
--enable-sysvshm
--enable-wddx
--with-xmlrpc
--with-xsl
--enable-zip
--with-zlib
--enable-discard-path
--enable-force-cgi-redirect
--enable-magic-quotes
--enable-sigchild
- -with-ncurses
--enable-pcntl
Then configure reports that many components are missing, alas. . Fill in the three components one by one, such as bz2, zlib and ncurses. After adding the three components,
configure was immediately successful. What next? make ok make test Something went wrong. . . . . ? ? I am speechless but make install
ok

requires php configuration
Create the php.ini file.
Write the following configuration:
error_log = /usr/local/php/php_error.log
date.timezone = "Asia/ShangHai"
session.save_path = "/tmp"



Modify conf/httpd.conf and fill in LoadModules php5_modules modules/libphp5.so
AddType application/x-httpd-php .php .html
AddType application/x-httpd -php-source .phps

Other configuration information of apache is also written in the httpd.conf file. For example home directory location:

www.bkjia.comtruehttp: //www.bkjia.com/PHPjc/325287.htmlTechArticlelinux version: ubuntu 12.04 Today I completed the configuration of php mysql and apache, mainly source code configuration, apache is mainly 2.4. 2 version php is mainly 5.3.11 version mysql is mainly 5.1.62...
Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn