He visto algunas preguntas que parecen similares, pero todas terminaron en varios sitios . Por mantenimiento, rendimiento y seguridad, no quiero usar multisitio. Así que por favor tengan paciencia conmigo.
Esto es lo que estoy pensando:
.
|_____branch1 // for branch1.domain.com
| |_____themes
| |_____plugins
|
|_____branch2 // for branch2.domain.com
| |_____themes
| |_____plugins
|
|_____branch3 // for branch3.domain.com
| |_____themes
| |_____plugins
|
|_____index.php
|_____WordPress
|_____wp-config.php
Como puede ver, cada dominio tiene su propia base de datos y directorio de contenido, pero solo una instancia de WordPress. Ahora, los temas, complementos y bases de datos se vuelven más pequeños e independientes. Entonces, sería mucho más fácil de mantener, escalar ...
Pero es posible? Si ha experimentado el mismo problema antes, ¡comparta sus pensamientos! Realmente aprecio tu ayuda.
customization
multisite
SarahCoding
fuente
fuente

Respuestas:
Como @ tom-j-nowell dijo en un comentario a OP, multisitio puede hacer esto más fácil.
El rendimiento y la seguridad no son realmente un problema para multisitio (al menos, no más de lo que son para instalaciones regulares), pero estoy de acuerdo en que multisitio a veces puede ser un problema, porque muchos complementos (ya sea personalizados o de terceros) pueden no serlo. funciona correctamente en varios sitios, o tal vez porque desea mantener a los usuarios de diferentes sitios web completamente separados.
Dicho esto, lo que quieres lograr no es tan difícil.
Lo que necesita cambiar entre la instalación es:
Esa configuración se puede hacer usando constantes en
wp-config.phpsu único problema es cómo cambiarlos en función de la URL.La variable del servidor
'SERVER_NAME'debería funcionar para usted, al menos si su servidor web está configurado correctamente.Por ejemplo, puede crear una carpeta
/confcon el mismo nivel dewp-config.phparchivo y/WordPresscarpeta.En esa carpeta puede agregar algunos archivos:
branch1.domain.com.confbranch2.domain.com.confbranch3.domain.com.confdentro de cada uno de ellos puedes hacer algo como
Esto cambiará en cada archivo de configuración de acuerdo con la "rama".
Después de eso, en su único
wp-config.phppuede algo así como:Lo que sucede arriba es que, en función del nombre del servidor, carga un archivo de configuración diferente (si se encuentra) y si el archivo de configuración no define ninguna de las configuraciones predeterminadas (o si no se encuentra el archivo), las configuraciones se establecen de manera predeterminada.
Lo bueno es que para agregar una nueva rama, solo necesita crear la carpeta de la rama y proporcionar un
.confnombre después del nuevo dominio de la rama, y listo, no hay nada que cambiar en el lado de WP.La línea:
es donde obtengo el nombre de dominio. Como primera opción, estoy usando una variable de entorno, porque hay posibilidades de
$_SERVER['SERVER_NAME']que no funcione en un contexto de línea de comando, como cuando usamos WP CLI. En esas situaciones, puede establecer una variable de entorno para obligar a WP a usar la configuración de una rama específica.Tenga en cuenta que en los archivos de configuración específicos de la rama, estoy cambiando la
WP_CONTENT_DIRcarpeta y que automáticamente configurará los complementos y la carpeta de temas a los relacionados/pluginsy/themessubcarpetas rama.Un posible problema aquí es si desea compartir la
/uploadscarpeta (donde se cargan los archivos).De manera predeterminada, esa carpeta es una subcarpeta del directorio de contenido, por lo que el uso del flujo de trabajo anterior será una
/uploadssubcarpeta de cada carpeta raíz de rama.Si eso no es un problema para usted, simplemente vaya con él, de lo contrario, la solución más fácil sería hacer que
/uploadsen cada carpeta de sucursal un enlace simbólico a la carpeta de cargas reales que desea compartir.fuente
$_SERVER['SERVER_NAME']no sea confiable ./uploadsdir no es problema. También lo he probado con WP CLI, si pasamos--urlparámetros para cada sitio, funciona normalmente :)server_nameen nginx oServerNameen Apache o lo que se ajuste a su servidor web,$_SERVER['SERVER_NAME']simplemente funcionará. Incluso si WP CLI puede funcionar usando--urlparámetros, otras herramientas de línea de comandos pueden tener problemas si no usa la variable de entorno. WP CLI "simula" la URL de la solicitud en un contexto CLI, probablemente otros comandos no lo harán.SERVER_NAMEesté configurado correctamente. Sobre env vars, he usado phpdotenv para solucionarlo. Actualmente, todo parece funcionar muy bien :)Esto es posible con un enlace simbólico y un poco de planificación. Hice un poco de búsqueda en la red por lo mismo. Finalmente, junte todas las cosas y póngalo a funcionar.
He estado ejecutando algunos sitios web, todos comparten el mismo tema y carpeta de complementos. Las mismas carpetas funcionan para sitios múltiples y únicos. Pero debe tener cuidado con ciertos complementos que pueden ser solo sitios múltiples / únicos y ser extravagantes.
He creado un directorio como master-tnp / themes y master-tnp / plugins. Luego enlace simbólicamente a su directorio de wordpress usando el comando ln -s.
Las trampas también están en las configuraciones del servidor. Asegúrese de que la directiva seguir enlaces simbólicos esté configurada para permitir.
Si desea utilizar una instalación única de WordPress, he reunido una guía detallada sobre cómo lo hice en https://vaish.co/multiple-sites-single-wordpress-directory
fuente