Difference between revisions of "Apache HTTP Server (Español)"

From ArchWiki
Jump to: navigation, search
m (categorías actualizadas)
(/ actualizando artículo */)
Line 1: Line 1:
 
[[Category:Daemons y servicios del sistema (Español)]]
 
[[Category:Daemons y servicios del sistema (Español)]]
 
[[Category:CÓMOs (Español)]]
 
[[Category:CÓMOs (Español)]]
 +
 
{{i18n_links_start}}
 
{{i18n_links_start}}
 
{{i18n_entry|English|LAMP}}
 
{{i18n_entry|English|LAMP}}
{{i18n_entry|English|LAMP (Español)}}
+
{{i18n_entry|Español|LAMP (Español)}}
 
{{i18n_entry|Italiano|LAMP (Italiano)}}
 
{{i18n_entry|Italiano|LAMP (Italiano)}}
{{i18n_entry|Русский|LAMP (russian)}}
+
{{i18n_entry|Русский|LAMP (Русский)}}
 
{{i18n_entry|Česky|LAMP_(Česky)}}
 
{{i18n_entry|Česky|LAMP_(Česky)}}
 
{{i18n_entry|简体中文|LAMP(简体中文)}}
 
{{i18n_entry|简体中文|LAMP(简体中文)}}
 
{{i18n_links_end}}
 
{{i18n_links_end}}
  
(This wiki post copied from: http://bbs.archlinux.org/viewtopic.php?t=2409)
+
LAMP, es el acrónimo para referirse a un conjunto de software, utilizado para ejecutar sitios web dinámicos o servicios.
 +
 
 +
* '''L'''inux refiriendose al sistema operativo, en este caso Arch Linux ;);
 +
* '''A'''pache, el servidor Web;
 +
* '''M'''ySQL, el sistema administrador de base de datos;
 +
* '''P'''HP u otros, p.e. Perl, Python.
  
(This is going to be the translation of this Document to Spanish)
 
(Esta será la traducción de este documento al español)
 
  
 
===Apache, PHP, y MySQL===
 
===Apache, PHP, y MySQL===
Line 21: Line 25:
 
====Instalar Paquetes====
 
====Instalar Paquetes====
 
   <pre>
 
   <pre>
   # pacman -Sy
+
   # pacman -Sy apache php mysql</pre>
  # pacman -S apache
+
  # pacman -S php
+
  # pacman -S mysql
+
  </pre>
+
 
+
Si lo desea, puede instalar sólo Apache, Apache y PHP, o los tres. Este documento asume que instalará
+
los tres, pero si quiere, puede detenerse después de cualquiera de las secciones.
+
  
 +
Si lo desea, puede instalar Apache/PHP/MySQL por separado. Este documento asume que instalará
 +
los tres, pero si lo desea, puede realizar cualquiera de las secciones que apliquen al software instalado.
  
 
====Configurar Apache====
 
====Configurar Apache====
* Añada la siguiente línea a <pre>/etc/hosts</pre> (Si el fichero no existe deberá crearlo)
+
* Añada la siguiente línea a <code>/etc/hosts</code> (Si el archivo no existe deberá crearlo)
 
   <pre>127.0.0.1  localhost.localdomain  localhost</pre>
 
   <pre>127.0.0.1  localhost.localdomain  localhost</pre>
  
'''Nota:''' Si desea un hostname diferente, añádalo al final de la línea:
+
{{Box Note|Si desea un hostname diferente, añádalo al final de la línea:}}
  
 
   <pre>127.0.0.1  localhost.localdomain  localhost myhostname</pre>
 
   <pre>127.0.0.1  localhost.localdomain  localhost myhostname</pre>
  
* Edite <pre>/etc/rc.conf</pre>:
+
* Edite <code>/etc/rc.conf</code>. Si define un hostname en el paso anterior,
 
+
la variable HOSTNAME debe ser igual. Si no, deje solamente "localhost":
Si define un hostname en el paso 2, la variable HOSTNAME debe ser igual. Si no, deje solamente localhost:
+
 
   <pre>
 
   <pre>
 
   #
 
   #
 
   # Networking
 
   # Networking
 
   #
 
   #
   HOSTNAME="localhost"
+
   HOSTNAME="localhost"</pre>
   </pre>
+
 
 +
* Comentar un modulo en el archivo de configuración de Apache
 +
  <pre>
 +
  # nano /etc/httpd/conf/httpd.conf</pre>
 +
 
 +
  <pre>
 +
  LoadModule unique_id_module        modules/mod_unique_id.so</pre>
 +
en
 +
  <pre>
 +
   #LoadModule unique_id_module        modules/mod_unique_id.so</pre>
  
 
* Ejecute en una terminal (como root):
 
* Ejecute en una terminal (como root):
 
   <pre># /etc/rc.d/httpd start</pre>
 
   <pre># /etc/rc.d/httpd start</pre>
  
*  Apache debería ahora estar corriendo. Verifíquelo visitando http://localhost/ en un navegador web. Debería ver una página simple de Arch Linux.
+
*  Apache debería ahora estar corriendo. Verifíquelo visitando http://localhost/ en un navegador web. Debería ver una página simple página de prueba de Apache.
  
* Edite <pre>/etc/rc.conf</pre> (para iniciar Apache en el arranque):
+
* Edite <code>/etc/rc.conf</code> (para iniciar Apache en el arranque):
   <pre>Daemons=(varios daemons ahora adiciona httpd)</pre>
+
   <pre>DAEMONS=(... varios daemons ... httpd)</pre>
'''O''' añada esta línea a <pre>rc.local</pre>:
+
'''O''' añada esta línea a <code>rc.local</code>:
   <pre># /etc/rc.d/httpd start</pre>
+
   <pre>/etc/rc.d/httpd start</pre>
  
* Si quiere activar los directorios de usuarios (ie: ~/public_html en la máquina es accesible como http://localhost/~user/) para estar disponibles en la web, descomente las siquientes líneas en /etc/httpd/conf/httpd.conf:
+
* Si quiere activar los directorios de usuario (p.e. <code>~/public_html</code> en la máquina es accesible como http://localhost/~usuario/) para estar disponibles en la web, descomente las siguientes líneas en <code>/etc/httpd/conf/extra/httpd-userdir.conf</code>:
  
 
   <pre>UserDir public_html</pre>
 
   <pre>UserDir public_html</pre>
Line 75: Line 82:
 
       Deny from all
 
       Deny from all
 
     </LimitExcept>
 
     </LimitExcept>
   </Directory>
+
   </Directory></pre>
  </pre>
+
  
asegúrese de que apache pueda ingresar al directorio de su home
+
Asegúrese de que Apache pueda ingresar al directorio home del usuario colocando los permisos correspondientes. El directorio del usuario y el directorio <code>~/public_html/</code> debe ser ejecutable para los otros ("el resto del mundo"). Esto sería suficiente:
   <pre> chmod 711 /home/user</pre>
+
 
 +
   <pre>
 +
  $ chmod o+x ~
 +
  $ chmod o+x ~/public_html</pre>
 +
 
 +
Existen algunas otras formas, más seguras de colocar los permisos mediante la creación de un grupo especial y permitiendo sólo al usuario Apache y otros requeridos entrar ahí... Dependiendo del nivel paranoico que se tenga.
 +
 
 +
=====Opciones adicionales=====
 +
Estas opciones en <code>/etc/httpd/conf/httpd.conf</code> pueden ser de interés:
 +
 
 +
El puerto que Apache utiliza para escuchar peticiones. Para el acceso a internet con router,
 +
se debe redireccinar a ese puerto.
 +
  <pre># Listen 80</pre>
 +
 
 +
Este es el correo electrónico del administrador que puede ser encontrado en las páginas de error por ejemplo.
 +
  <pre># ServerAdmin sample@sample.com</pre>
 +
 
 +
Este es el directorio donde se podrían colocar las páginas web.
 +
  <pre># DocumentRoot "/home/httpd/html"</pre>
 +
 
 +
Si se cambia el directorio raíz (DocumentRoot) no se debe olvidar cambiar el siguiente elemento.
 +
  <pre># <Directory "/home/httpd/html"></pre>
  
 
====Configurar PHP====
 
====Configurar PHP====
PHP ahora esta disponible prácticamente al instalarlo.
+
PHP ahora esta disponible prácticamente después de instalarlo.
 +
 
 +
* Descomente esta línea en <code>/etc/httpd/conf/httpd.conf</code>
 +
  <pre>#LoadModule php5_module modules/libphp5.so</pre>
 +
 
 +
* Para PHP5 los archivos manejadores ya están configurados
 +
  <pre>
 +
  #
 +
  # DirectoryIndex: sets the file that Apache will serve if a directory
 +
  # is requested.
 +
  #
 +
  <IfModule dir_module>
 +
      <IfModule mod_php5.c>
 +
          DirectoryIndex index.php index.html
 +
          AddType application/x-httpd-php .php
 +
          AddType application/x-httpd-php-source .phps
 +
      </IfModule>
 +
      DirectoryIndex index.html
 +
  </IfModule></pre>
 +
 
 +
* Recordad agregar un archivo manejador para .phtml si es necesario:
 +
  <pre>DirectoryIndex index.php index.phtml index.html</pre>
 +
 
 +
* Si se desea el módulo libGD, edite <code>/etc/php/php.ini</code> y descomente la siguiente línea (''quitando el ;''):
 +
  <pre>;extension=gd.so</pre>
  
* Descomente esta línea en <pre>/etc/httpd/conf/httpd.conf</pre>
+
* Si el DocumentRoot está fuera de <code>/home/</code>, agergarlo
   <pre>#LoadModule php4_module /usr/lib/apache/libphp4.so</pre>
+
en la variable <code>open_basedir</open> en el archivo <code>/etc/php/php.ini</code> como:
 +
   <pre>open_basedir = /home/:/tmp/:/usr/share/pear/:/ruta/al/documentroot</pre>
  
 
* Reinicie el servidor Apache para que los cambios tengan efecto (como root):
 
* Reinicie el servidor Apache para que los cambios tengan efecto (como root):
Line 93: Line 145:
 
   <pre>
 
   <pre>
 
   <html>
 
   <html>
   <title>This is Arch Linux, running PHP.</title>
+
   <title>Este es Arch Linux, ejecutando PHP.</title>
 
   <body>
 
   <body>
 
   <p>
 
   <p>
Line 101: Line 153:
 
   </p>
 
   </p>
 
   </body>
 
   </body>
   </html>
+
   </html></pre>
  </pre>
+
  
Guarde este archivo como "test.php" y copielo en <pre>/home/httpd/html/</pre> o en <pre>~/public_html</pre> si lo permitió en la configuración.
+
Guarde este archivo como <code>test.php</code> y copielo en <code>/home/httpd/html/</code> o en <code>~/public_html</code> si lo permitió en la configuración.
  
* Prueba PHP:
+
* Pruebe PHP en http://localhost/test.php o en http://localhost/~usuario/test.php
  http://localhost/test.php o http://localhost/~myname/test.php
+
  
====Configurar MySQL====
+
====Configurar el soporte para MySQL====
Haga ésto sólo si quiere activar el soporte para MySQL
+
Haga ésto sólo si quiere activar el soporte para MySQL. Configure previamente MySQL
 +
en los pasos descritos de [[MySQL|MySQL]]
  
* Edite <pre>/etc/php.ini</pre> y descomente las siquientes líneas:
+
* Edite <code>/etc/php/php.ini</code> y descomente la siguiente línea (''quitando el ;''):
 
   <pre>;extension=mysql.so</pre>
 
   <pre>;extension=mysql.so</pre>
  
Los dos siquientes pasos deberá hacerlos la primera vez que inicie /etc/rc.d/mysql. Heche un vistazo  a este archivo, si no está seguro.
+
* Si no ha configurado una contraseña de root para MySQL (en una terminal, como root):
 +
  <pre># mysqladmin -u root password 'roots_password'</pre>
  
* '''Puede''' necesitar configurar una contraseña y un grupo para mysql:
+
* Se pueden agregar usuarios con menos privilegios, para los scripts que desee ejecutar, editando las tablas que se encuentran en la base de datos <code>mysql</code>. Deberá reiniciar el servicio para que los cambios tomen efecto.
* Añada un grupo llamado mysql
+
No olvide revisar la tabla <code>mysql/users</code>. Si existe una segunda entrada para el usuario root y el hostname se deja sin ninguna clave establecida, cualquier persona de su máquina probablemente podría ganar el acceso total.
<pre># groupadd -g 89 mysql</pre>
+
Tal vez deba revisar la siguiente sección para estas labores.
* Añada el usuario mysql
+
<pre># useradd -u 89 -g mysql -d /var/lib/mysql -s /bin/false mysql</pre>
+
  
* Run in a root terminal (you don't need the --user option and chown if you let it run as root):
+
* Si se obtienen el mensaje "<code>error no. 2013: Lost Connection to mysql server during query</code>" instantaneamente después de intentar conectarse al daemon de MySQL mediante TCP/IP. Esto es por el sistema TCP wrappers (tcpd), el cual utiliza el sistema <code>hosts_access(5)</code> para permitir (allow) o denegar (disallow) las conexiones.
  <pre>
+
  # mysql_install_db --user=mysql
+
  # chown -R mysql.mysql /var/lib/mysql
+
  </pre>
+
  
Si confía en el script por defecto, pruebe:
+
Si se esta en este problema, asegurarse de agregar lo siguiente en el archivo <code>/etc/hosts.allow</code>:
  
* Test mysql (as root):
+
   <pre>
   <pre># /etc/rc.d/mysqld start
+
  # mysqld : ALL : ALLOW
   # mysql</pre>
+
   # mysqld-max : ALL : ALLOW
 +
  # y similar para otros daemons de MySQL.</pre>
  
* Cree una contraseña de root para mysql (en una terminal, como root):
+
{{Box Note|Los ejemplos anteriores son un caso simplista, diciendole a tcpd que permita todas las conexiones desde cualquier lugar. Se debe utilizar una selección más apropiada de fuentes permitidas en lugar de '''ALL'''. Sólo asegurese que localhost y la dirección IP (númerica o de DNS) de la interáz por la cuál se realice la conexión este especificada.}}
  <pre># mysqladmin -u root password 'roots_password'</pre>
+
  
* Agregue <pre>mysqld</pre> a la lista de daemons en <pre>/etc/rc.conf</pre> (Siga los ejemplos que ya hay en el archivo)
+
* Podría también ser necesario editar el archivo <code>/etc/my.cnf</code> y comentar la siguiente línea como sigue:
'''O''' agregue esta línea a <pre>/etc/rc.local</pre>
+
  <pre># skip-networking</pre>
  <pre># /etc/rc.d/mysqld start</pre>
+
 
+
* Para logearse a mysql, escriba (En una terminal, >hostname< reemplázelo según la línea que tenga en /etc/hosts)
+
  <pre># mysql -u root -h >hostname< -p</pre>
+
 
+
* Ud. puede agregar usuarios con menos privilegios, para los scripts que desee, editando las tablas que se encuentran en la base de datos "mysql". Deberá reiniciar el servicio para que los cambios tomen efectos.
+
<br> No olvide chequear la tabla de mysql/users. Si existe una segunda entrada para el root y su hostname sin ninguna clave establecida, cualquier persona de su máquina probablemente podría ganar el acceso total.
+
<br>Tal vez deba revisar la siguiente sección para estas labores.
+
  
 
====Configurar PHPMyAdmin====
 
====Configurar PHPMyAdmin====
Si Ud. o sus usuarios quieren usar [http://www.phpmyadmin.net PHPMyAdmin, podrían proceder de la siguiente manera:
+
Si se quiere utilizar [http://www.phpmyadmin.net PHPMyAdmin], podría proceder de la siguiente manera:
 +
 
 
* Instale el paquete
 
* Instale el paquete
 
   <pre>
 
   <pre>
   # pacman -S phpmyadmin
+
   # pacman -S phpmyadmin</pre>
  </pre>
+
  
* Edite el archivo de configuración para adaptarlo a sus necesidades: <pre>/home/httpd/html/phpMyAdmin/config.inc.php</pre>
+
* Edite el archivo de configuración para adaptarlo a sus necesidades: <code>/home/httpd/html/phpMyAdmin/config.inc.php</code>
<br><br>Inserte la cadena correspondiente a la variable PmaAbsoluteUri para que sea parecida a:
+
 
 +
Inserte la cadena correspondiente a la variable PmaAbsoluteUri para que sea parecida a:
 
<pre>$cfg[['PmaAbsoluteUri']] = 'http://>hostname</phpMyAdmin/';</pre>
 
<pre>$cfg[['PmaAbsoluteUri']] = 'http://>hostname</phpMyAdmin/';</pre>
<br>Rellene la información de su servidor MySQL. En PHPMyAdmin, se pueden definir multiples servidores en el arreglo 'Servers'. Para acceder a su base de datos MySQL, tiene que editar la primera entrada; puede ignorar las demás.
+
 
 +
Rellene la información de su servidor MySQL. En PHPMyAdmin, se pueden definir multiples servidores en el arreglo 'Servers'. Para acceder a su base de datos MySQL, tiene que editar la primera entrada; puede ignorar las demás.
 +
 
 
En un sistema normal sólo tendría que asignar el auth_type a http. Esto hace que PHPMyAdmin use el usuario y contraseñas ingresados por el navegador web para acceder al servidor de bases de datos, de esa manera, no se pueden realizar acciones que no estén permitidas para dicho usuario del servidor MySql.
 
En un sistema normal sólo tendría que asignar el auth_type a http. Esto hace que PHPMyAdmin use el usuario y contraseñas ingresados por el navegador web para acceder al servidor de bases de datos, de esa manera, no se pueden realizar acciones que no estén permitidas para dicho usuario del servidor MySql.
 +
 
<pre>
 
<pre>
$cfg[['Servers']][[$i]][['auth_type']]    = 'http';
+
$cfg[['Servers']][[$i]][['auth_type']]    = 'http';</pre>
</pre>
+
 
<br>'''Advertencia:''' otros métodos de autorización o el escribir contraseñas directamente en este archivo puede dañar la seguridad de la base de datos. Por defecto, este archivo es legible para todo el mundo.
+
'''Advertencia:''' otros métodos de autorización o el escribir contraseñas directamente en este archivo puede comprometer la seguridad de la base de datos. Por defecto, este archivo es legible para todo el mundo, por lo que es conveniente restringirlo.
  
* Para usar PHPMyAdmin apunta tu navegador web a: <pre>http://>hostname</phpMyAdmin/</pre>
+
* Para usar PHPMyAdmin dirigir el navegador web a <pre>http://>hostname</phpMyAdmin/</pre>

Revision as of 01:02, 13 July 2008

Template:I18n links start Template:I18n entry Template:I18n entry Template:I18n entry Template:I18n entry Template:I18n entry Template:I18n entry Template:I18n links end

LAMP, es el acrónimo para referirse a un conjunto de software, utilizado para ejecutar sitios web dinámicos o servicios.

  • Linux refiriendose al sistema operativo, en este caso Arch Linux ;);
  • Apache, el servidor Web;
  • MySQL, el sistema administrador de base de datos;
  • PHP u otros, p.e. Perl, Python.


Apache, PHP, y MySQL

Este documento describe como configurar el servidor web Apache en un sistema Arch Linux. Además explica como, opcionalmente, instalar PHP y MySQL e integrarlos con Apache.

Instalar Paquetes

  # pacman -Sy apache php mysql

Si lo desea, puede instalar Apache/PHP/MySQL por separado. Este documento asume que instalará los tres, pero si lo desea, puede realizar cualquiera de las secciones que apliquen al software instalado.

Configurar Apache

  • Añada la siguiente línea a /etc/hosts (Si el archivo no existe deberá crearlo)
127.0.0.1  localhost.localdomain   localhost

Template:Box Note

127.0.0.1  localhost.localdomain   localhost myhostname
  • Edite /etc/rc.conf. Si define un hostname en el paso anterior,

la variable HOSTNAME debe ser igual. Si no, deje solamente "localhost":

  #
  # Networking
  #
  HOSTNAME="localhost"
  • Comentar un modulo en el archivo de configuración de Apache
  # nano /etc/httpd/conf/httpd.conf
  LoadModule unique_id_module        modules/mod_unique_id.so

en

  #LoadModule unique_id_module        modules/mod_unique_id.so
  • Ejecute en una terminal (como root):
# /etc/rc.d/httpd start
  • Apache debería ahora estar corriendo. Verifíquelo visitando http://localhost/ en un navegador web. Debería ver una página simple página de prueba de Apache.
  • Edite /etc/rc.conf (para iniciar Apache en el arranque):
DAEMONS=(... varios daemons ... httpd)

O añada esta línea a rc.local:

/etc/rc.d/httpd start
  • Si quiere activar los directorios de usuario (p.e. ~/public_html en la máquina es accesible como http://localhost/~usuario/) para estar disponibles en la web, descomente las siguientes líneas en /etc/httpd/conf/extra/httpd-userdir.conf:
UserDir public_html

y

  <Directory /home/*/public_html>
    AllowOverride FileInfo AuthConfig Limit Indexes
    Options MultiViews Indexes SymLinksIfOwnerMatch ExecCGI
    <Limit GET POST OPTIONS PROPFIND>
      Order allow,deny
      Allow from all
    </Limit>
    <LimitExcept GET POST OPTIONS PROPFIND>
      Order deny,allow
      Deny from all
    </LimitExcept>
  </Directory>

Asegúrese de que Apache pueda ingresar al directorio home del usuario colocando los permisos correspondientes. El directorio del usuario y el directorio ~/public_html/ debe ser ejecutable para los otros ("el resto del mundo"). Esto sería suficiente:

  $ chmod o+x ~
  $ chmod o+x ~/public_html

Existen algunas otras formas, más seguras de colocar los permisos mediante la creación de un grupo especial y permitiendo sólo al usuario Apache y otros requeridos entrar ahí... Dependiendo del nivel paranoico que se tenga.

Opciones adicionales

Estas opciones en /etc/httpd/conf/httpd.conf pueden ser de interés:

El puerto que Apache utiliza para escuchar peticiones. Para el acceso a internet con router, se debe redireccinar a ese puerto.

# Listen 80

Este es el correo electrónico del administrador que puede ser encontrado en las páginas de error por ejemplo.

# ServerAdmin sample@sample.com

Este es el directorio donde se podrían colocar las páginas web.

# DocumentRoot "/home/httpd/html"

Si se cambia el directorio raíz (DocumentRoot) no se debe olvidar cambiar el siguiente elemento.

# <Directory "/home/httpd/html">

Configurar PHP

PHP ahora esta disponible prácticamente después de instalarlo.

  • Descomente esta línea en /etc/httpd/conf/httpd.conf
#LoadModule php5_module modules/libphp5.so
  • Para PHP5 los archivos manejadores ya están configurados
  #
  # DirectoryIndex: sets the file that Apache will serve if a directory
  # is requested.
  #
  <IfModule dir_module>
      <IfModule mod_php5.c>
          DirectoryIndex index.php index.html
          AddType application/x-httpd-php .php
          AddType application/x-httpd-php-source .phps
      </IfModule>
      DirectoryIndex index.html
  </IfModule>
  • Recordad agregar un archivo manejador para .phtml si es necesario:
DirectoryIndex index.php index.phtml index.html
  • Si se desea el módulo libGD, edite /etc/php/php.ini y descomente la siguiente línea (quitando el ;):
;extension=gd.so
  • Si el DocumentRoot está fuera de /home/, agergarlo

en la variable open_basedir</open> en el archivo <code>/etc/php/php.ini como:

open_basedir = /home/:/tmp/:/usr/share/pear/:/ruta/al/documentroot
  • Reinicie el servidor Apache para que los cambios tengan efecto (como root):
# /etc/rc.d/httpd restart
  • Pruebe PHP con un simple, pero muy informativo script:
  <html>
  <title>Este es Arch Linux, ejecutando PHP.</title>
  <body>
  <p>
  <?php
    phpinfo();
  ?>
  </p>
  </body>
  </html>

Guarde este archivo como test.php y copielo en /home/httpd/html/ o en ~/public_html si lo permitió en la configuración.

Configurar el soporte para MySQL

Haga ésto sólo si quiere activar el soporte para MySQL. Configure previamente MySQL en los pasos descritos de MySQL

  • Edite /etc/php/php.ini y descomente la siguiente línea (quitando el ;):
;extension=mysql.so
  • Si no ha configurado una contraseña de root para MySQL (en una terminal, como root):
# mysqladmin -u root password 'roots_password'
  • Se pueden agregar usuarios con menos privilegios, para los scripts que desee ejecutar, editando las tablas que se encuentran en la base de datos mysql. Deberá reiniciar el servicio para que los cambios tomen efecto.

No olvide revisar la tabla mysql/users. Si existe una segunda entrada para el usuario root y el hostname se deja sin ninguna clave establecida, cualquier persona de su máquina probablemente podría ganar el acceso total. Tal vez deba revisar la siguiente sección para estas labores.

  • Si se obtienen el mensaje "error no. 2013: Lost Connection to mysql server during query" instantaneamente después de intentar conectarse al daemon de MySQL mediante TCP/IP. Esto es por el sistema TCP wrappers (tcpd), el cual utiliza el sistema hosts_access(5) para permitir (allow) o denegar (disallow) las conexiones.

Si se esta en este problema, asegurarse de agregar lo siguiente en el archivo /etc/hosts.allow:

  # mysqld : ALL : ALLOW
  # mysqld-max : ALL : ALLOW
  # y similar para otros daemons de MySQL.

Template:Box Note

  • Podría también ser necesario editar el archivo /etc/my.cnf y comentar la siguiente línea como sigue:
# skip-networking

Configurar PHPMyAdmin

Si se quiere utilizar PHPMyAdmin, podría proceder de la siguiente manera:

  • Instale el paquete
  # pacman -S phpmyadmin
  • Edite el archivo de configuración para adaptarlo a sus necesidades: /home/httpd/html/phpMyAdmin/config.inc.php

Inserte la cadena correspondiente a la variable PmaAbsoluteUri para que sea parecida a:

$cfg[['PmaAbsoluteUri']] = 'http://>hostname</phpMyAdmin/';

Rellene la información de su servidor MySQL. En PHPMyAdmin, se pueden definir multiples servidores en el arreglo 'Servers'. Para acceder a su base de datos MySQL, tiene que editar la primera entrada; puede ignorar las demás.

En un sistema normal sólo tendría que asignar el auth_type a http. Esto hace que PHPMyAdmin use el usuario y contraseñas ingresados por el navegador web para acceder al servidor de bases de datos, de esa manera, no se pueden realizar acciones que no estén permitidas para dicho usuario del servidor MySql.

$cfg[['Servers']][[$i]][['auth_type']]     = 'http';

Advertencia: otros métodos de autorización o el escribir contraseñas directamente en este archivo puede comprometer la seguridad de la base de datos. Por defecto, este archivo es legible para todo el mundo, por lo que es conveniente restringirlo.

  • Para usar PHPMyAdmin dirigir el navegador web a
    http://>hostname</phpMyAdmin/