Problema ao alterar a raiz do documento no Ubuntu 16.04

0

Eu mudei recentemente para o Ubuntu 16.04 do Windows e estou tentando configurar o ambiente de desenvolvimento web. Eu instalei com sucesso o apache, mysql e php e tanto o html quanto o php (criou um script de teste através do sudo nano) são renderizados perfeitamente a partir de /var/www .

Então eu tentei criar um novo arquivo através de texto sublime no diretório /var/www apenas para perceber que o arquivo de salvamento dava um erro de acesso negado. Então, isso me levou a um novo artigo sobre permissões, etc, e percebi que provavelmente não é uma boa idéia alterar as permissões desse diretório.

Procurei artigos sobre como mover a raiz do documento do apache para outro lugar. Em seguida, criei um novo diretório de projetos / web em /home/user e alterei o DocumentRoot em /etc/apache2/sites-available/000-default.conf (estou usando o apache 2.4.18). Fiz as alterações relevantes no /etc/apache2/apache2.conf para alterar o caminho <Directory> também. Reiniciou o apache e o DocuemntRoot foi alterado, mas não está renderizando nenhum php. Mesmo o phpmyadmin, que estava trabalhando anteriormente através do link , não está mais funcionando.

  • alterado em /etc/apache2/sites-available/000-default.conf:
    DocumentRoot /var/www/html
    para DocumentRoot /home/{user}/projects/web

  • Alterado no /etc/apache2/apache2.conf:
    <Directory /var/www/> Options Indexes FollowSymLinks AllowOverride None Require all granted </Directory>
    para <Directory /home/{user}/projects/web/> Options Indexes FollowSymLinks AllowOverride None Require all granted</Directory>

Alguém pode me ajudar como eu posso mudar o DocumentRoot e ainda ter o php e o phpmyadmin funcionando?

    
por A. Munir 18.02.2017 / 10:10

1 resposta

2

Primeiro corrija o Apaches2

Você aparentemente quebrou o Apache2. Você deve usar as configurações de host padrão e criar um host virtual para o diretório raiz personalizado de alterações desejado. Remova ou renomeie os arquivos de configuração que você editou e restaure os arquivos originais.

Use o arquivo 000-default.conf padrão como modelo. Copie-o para um nome para seu host virtual e faça modificações em seu arquivo personalizado.

Você pode renomear os arquivos usando estas etapas:

$ cd /etc/apache2/sites-available
$ sudo mv 000-default.conf mysite.conf
$ cd /etc/apache2
$ sudo mv apache2.conf apache2.conf.test

Agora restaure os arquivos padrão com esta linha de comando:

$ sudo apt -o Dpkg::Options::="--force-confmiss" install --reinstall apache2

Agora crie seu host virtual, "mysite.com" . Você pode substituir o /home/web/mysite em qualquer diretório. No seu caso, você pode usar /home/{user}/projects/web .

$ cd /etc/apache2/sites-available
$ sudo cp 000-default.conf mysite.conf
$ sudo mkdir -p /home/web/mysite/www
$ sudo mkdir -p /home/web/mysite/log

Se o host mysite.com não existir, crie-o localmente com:

$ gksudo gedit /etc/hosts

Adicione ao arquivo hosts :

127.0.0.1  mysite.com

Agora edite seu arquivo mysite.conf para apontar para a opção Document Root .

$ pksudo gedit /etc/apache2/sites-available/mysite.conf

Faça as seguintes alterações neste arquivo. Essa é a diferença entre o arquivo 000-default.conf e o arquivo mysite.conf recém-criado. A diferença é destacada no tipo negrito .

&ltVirtualHost *:80&gt
        # The ServerName directive sets the request scheme, hostname and port that
        # the server uses to identify itself. This is used when creating
        # redirection URLs. In the context of virtual hosts, the ServerName
        # specifies what hostname must appear in the request's Host: header to
        # match this virtual host. For the default virtual host (this file) this
        # value is not decisive as it is used as a last resort host regardless.
        # However, you must set it for any further virtual host explicitly.
        ServerName mysite.com

        ServerAdmin webmaster@localhost
        DocumentRoot /home/web/mysite/www


        &ltDirectory /&gt
                Options +FollowSymLinks +ExecCGI +Includes
                Require all granted
        &lt/Directory&gt


        # Available loglevels: trace8, ..., trace1, debug, info, notice, warn,
        # error, crit, alert, emerg.
        # It is also possible to configure the loglevel for particular
        # modules, e.g.
        #LogLevel info ssl:warn

        ErrorLog /home/web/mysite/log/error.log
        CustomLog /home/web/mysite//access.log combined

        # For most configuration files from conf-available/, which are
        # enabled or disabled at a global level, it is possible to
        # include a line for only one particular virtual host. For example the
        # following line enables the CGI configuration for this host only
        # after it has been globally disabled with "a2disconf".
        #Include conf-available/serve-cgi-bin.conf
&lt/VirtualHost&gt

# vim: syntax=apache ts=4 sw=4 sts=4 sr noet

Agora, ative o novo site com:

$ sudo a2ensite mysite.conf

Ao fazer uma alteração nos arquivos de configuração do Apache , reinicie o serviço com:

$ sudo systemctl restart apache2

Gravar permissões no diretório e arquivos do VirtualHost:

Você pode usar os comandos chown e chgrp para alterar o proprietário dos arquivos e pastas de /home/web/mysite/www . Se eles forem de propriedade do seu ID do usuário, você terá acesso de leitura e gravação aos arquivos e pastas.

Você também pode criar um grupo específico e adicionar usuários ao grupo específico para que o usuário desse grupo tenha acesso de leitura / gravação aos arquivos e pastas.

A utilização desta última consideração pode ser uma alternativa de segurança melhor do que conceder a outros usuários acesso em grupo a arquivos e pastas em seu /home space.

    
por L. D. James 18.02.2017 / 21:59