mysql https://drupaladicto.com/ es Como borrar restos de un campo desde Mysql https://drupaladicto.com/snippet/como-borrar-restos-de-un-campo-desde-mysql <span class="field field--name-title field--type-string field--label-hidden">Como borrar restos de un campo desde Mysql</span> <div class="clearfix text-formatted field field--name-field-snippet-descripcion field--type-text-long field--label-above"> <div class="field__label">Descripción</div> <div class="field__item">En algunos casos, cuando instalas módulos personalizados, es posible que, al desinstalarlos Drupal, no te deje volver a instalarlos, porque existe configuración guardada en base de datos. Es posible borrar directamente los campos en la base de datos, con el siguiente código.</div> </div> <span class="field field--name-uid field--type-entity-reference field--label-hidden"><span lang="" about="/luis-alberto-mejia" typeof="schema:Person" property="schema:name" datatype="">webmaster</span></span> <span class="field field--name-created field--type-created field--label-hidden">Mié, 29/11/2023 - 16:12</span> <div class="clearfix text-formatted field field--name-field-instrucciones field--type-text-long field--label-above"> <div class="field__label">Instrucciones</div> <div class="field__item"><p>Para eliminar restos de algún campo de Drupal, directamente en base de datos, sigue los siguientes pasos:</p> <ol><li>Abre el gestor de la base de datos</li> <li>Abre la consola que te permite ejecutar comandos de mysql</li> <li>Añade el siguiente código, modificando el nombre por el campo que quieres borrar.</li> </ol><p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 59.44%;" data-ratio="59.44" data-b-token="b-ee3875d645f" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img class="img-fluid media__element b-lazy b-filter" data-entity-uuid="f1cc674c-ca35-4686-98c7-b7202e6d74d9" alt="Snippet | www.drupaladicto.com - Consultor especializado en Drupal y Symfony" decoding="async" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/borrar-campo-mysql.png?itok=N0FRB24f" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="1102" height="655" typeof="foaf:Image" /></div></div> </div> </div> <div class="clearfix text-formatted field field--name-field-codigo field--type-text-long field--label-hidden field__item">DELETE FROM config where name='field.storage.paragraph.cfull_video'</div> <div class="field field--name-field-snippet-paginador field--type-image field--label-above"> <div class="field__label">Paginador</div> <div class="field__item"> <img src="/sites/default/files/default_images/snippet-pager.png" width="100" height="100" alt="Snippet | www.drupaladicto.com - Consultores especializados en Drupal y Symfony" title="Snippet | www.drupaladicto.com - Consultores especializados en Drupal y Symfony" loading="lazy" typeof="foaf:Image" class="img-fluid" /> </div> </div> <div class="field field--name-field-categoria-snippet field--type-entity-reference field--label-above"> <div class="field__label">Categoría</div> <div class="field__items"> <div class="field__item"><a href="/categoria/mysql" hreflang="es">mysql</a></div> <div class="field__item"><a href="/categoria/fields" hreflang="es">fields</a></div> <div class="field__item"><a href="/categoria/campo" hreflang="es">campo</a></div> <div class="field__item"><a href="/categoria/campos" hreflang="es">campos</a></div> <div class="field__item"><a href="/categoria/borrar" hreflang="es">borrar</a></div> <div class="field__item"><a href="/categoria/eliminar" hreflang="es">eliminar</a></div> </div> </div> <div class="field field--name-field-portada-snippet field--type-entity-reference field--label-above"> <div class="field__label">Portada</div> <div class="field__item"><article class="media media--type-imagen media--view-mode-default"> <div class="field field--name-field-media-image field--type-image field--label-visually_hidden"> <div class="field__label visually-hidden">Imagen</div> <div class="field__item"> <img src="/sites/default/files/styles/max_325x325/public/imagenes/portada-snippet-grande.png?itok=JZyTAbRq" width="325" height="176" alt="Snippet | www.drupaladicto.com - Consultor especializado en Drupal y Symfony" title="Snippet | www.drupaladicto.com - Consultor especializado en Drupal y Symfony" loading="lazy" typeof="foaf:Image" class="img-fluid image-style-max-325x325" /> </div> </div> </article> </div> </div> Wed, 29 Nov 2023 15:12:51 +0000 webmaster 477 at https://drupaladicto.com Can't install module because configuration already exists in active configuration https://drupaladicto.com/actualidad/cant-install-module-because-configuration-already-exists-active-configuration <span class="field field--name-title field--type-string field--label-hidden">Can&#039;t install module because configuration already exists in active configuration</span> <span class="field field--name-uid field--type-entity-reference field--label-hidden"><span lang="" about="/luis-alberto-mejia" typeof="schema:Person" property="schema:name" datatype="">webmaster</span></span> <span class="field field--name-created field--type-created field--label-hidden">Jue, 12/10/2023 - 20:11</span> <div class="field field--name-field-contenidos-post field--type-entity-reference-revisions field--label-visually_hidden"> <div class="field__label visually-hidden">Contenidos</div> <div class="field__items"> <div class="field__item"> <div class="paragraph paragraph--type--bloque-parrafo paragraph--view-mode--default"> <div class="clearfix text-formatted field field--name-field-textos-curso field--type-text-long field--label-hidden field__item"><p>     Es posible, que al trabajar con módulos personalizados en Drupal, hayas querido desinstalarlo y reinstalarlo para aplicar algún cambio, pero Drupal no te permite la reinstalación y, en su lugar, te presenta un error en pantalla indicando que "El módulo no puede instalarse, porque ya existe una configuración previa."</p> <pre id="page-subtitle"> Can't install module because configuration already exists in active configuration</pre> <h2>   Explicación</h2> <p>     Cuando instalamos un módulo en Drupal, se añaden varias tablas en base de datos que incluyen, el equivalente a los archivos de configuración <strong>.yml</strong>, como "<strong><em>core.entity_form_display.paragraph.footer_landing.default</em></strong>" o, como en de los campos relacionados con el contenido, ej.: "<strong><em>field.field.paragraph.footer_landing.fl_contents</em></strong>". </p> <p>     Toda la información relacionada con la configuración de los módulos, se añade dentro de la tabla <strong>config</strong>; normalmente, si desistalamos un módulo contribuido, todos los datos son elmininados en el momento de la desinstalación y podremos reinstalarlo, sin sorpresas, siempre que no tenga alguna dependencia con otros módulos o con contenidos creados previamente, utilizando dicho módulo.</p> <p>     En el caso de los módulos personalizados, en la mayoría de los casos, este proceso no se ejecuta correctamente, dejando presentes los restos del módulo, dentro de la tabla config; por esta razón, al intentar reinstalarlo, Drupal no nos permite hacerlo y lanza esta alerta.</p> <p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 48.07%;" data-ratio="48.07" data-b-token="b-1d85b7d88ac" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img data-entity-uuid="e78af902-d1cb-4f82-946a-ae4720aa93dc" class="img-fluid media__element b-lazy b-filter" alt="Borrar modulo en base de datos | www.drupaladicto.com - Consultor especializado en drupal y symfony" decoding="async" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/tabla-config.png?itok=ceN_A468" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="905" height="435" typeof="foaf:Image" /></div></div> </div> </div> </div> <div class="field__item"> <div class="paragraph paragraph--type--bloque-parrafo paragraph--view-mode--default"> <div class="clearfix text-formatted field field--name-field-textos-curso field--type-text-long field--label-hidden field__item"><h2>   Como eliminar restos de un módulo custom en Base de datos</h2> <p>     Según la página oficial de Drupal, podremos eliminar un módulo de varias maneras, ya sea mediante comandos de Drush o directamente ejecutando un par de comandos en la base de datos, de nuestra instalación; si quieres explorar y comprobar, algunas de estas opciones. <a href="https://www.drupal.org/node/157632">HAZ CLIC AQUI</a></p> <p>     En mi caso, tengo instalado un proyecto con Drupal 10, y el error me saltó con uno de mis módulos personalizados; ya me había sucedido anteriormente con versiones de Drupal 9, pero no lo documenté en su momento y por esta razón, he aprovechado para hacerlo.</p> <h2>   Pasos para eliminar un módulo custom desde base de datos en Drupal.</h2> <p>     Básicamente, lo que tenemos que hacer para desinstalar el módulo y todos los campos relacionados, es lo siguiente:</p> <ol><li>Accederemos a nuestra base de datos, preferiblemente, utilizando algún programa con interfaz gráfica de administración. Ej: (PhpMyAdmin o Adminer).</li> <li>Abriremos la ventana que nos permite ejecutar consultas sobre la base de datos y añadiremos el siguiente comando, modificando los nombres. <p> </p> <pre> SELECT * FROM config where name='field.field.paragraph.footer_landing.fl_contents'</pre> </li> <li>Una vez nos aparezca el nombre del módulo o campo, podremos eliminarlo utilizando la misma interfaz de administrado de base de datos.</li> </ol><p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 38.99%;" data-ratio="38.99" data-b-token="b-9fdd6551b05" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img class="img-fluid media__element b-lazy b-filter" data-entity-uuid="46c324ea-b4fd-40ad-b272-05dc2aadab07" alt="Borrar modulo en base de datos | www.drupaladicto.com - Consultor especializado en drupal y symfony" decoding="async" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/borrar-adminer.png?itok=asac8pzB" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="990" height="386" typeof="foaf:Image" /></div></div> </div> </div> </div> </div> </div> <div class="field field--name-field-categoria-post field--type-entity-reference field--label-above"> <div class="field__label">Categoría</div> <div class="field__items"> <div class="field__item"><a href="/categoria/mysql" hreflang="es">mysql</a></div> <div class="field__item"><a href="/categoria/custom-module" hreflang="es">custom module</a></div> <div class="field__item"><a href="/categoria/base-de-datos" hreflang="es">base de datos</a></div> <div class="field__item"><a href="/categoria/bases-de-datos" hreflang="es">bases de datos</a></div> <div class="field__item"><a href="/categoria/module" hreflang="es">module</a></div> <div class="field__item"><a href="/categoria/modulos" hreflang="es">módulos</a></div> <div class="field__item"><a href="/categoria/modulo" hreflang="es">modulo</a></div> <div class="field__item"><a href="/categoria/database" hreflang="es">database</a></div> <div class="field__item"><a href="/categoria/tablas" hreflang="es">tablas</a></div> </div> </div> Thu, 12 Oct 2023 18:11:14 +0000 webmaster 473 at https://drupaladicto.com Docker for Drupal | Importar proyecto existente https://drupaladicto.com/curso/entornos-locales/docker-drupal-importar-proyecto-existente <span class="field field--name-title field--type-string field--label-hidden">Docker for Drupal | Importar proyecto existente</span> <div class="field field--name-field-contenidos-cap-gratis field--type-entity-reference-revisions field--label-hidden field__items"> <div class="field__item"> <style>#video-only-874 .play-btn:hover::after { border-left: 15px solid #1fd7d9; transform: scale(20); border-left: 15px solid #fff; } #video-only-874 .play-btn::before { border: 5px solid #1fd7d9; } #video-only-874 .play-btn { background: radial-gradient(#1fd7d9 50%, rgba(66, 109, 202, 0.4) 52%); }</style> <div class="paragraph paragraph--type--video-only paragraph--view-mode--default" id="vol-874"> <section id="video-only-874" class="about area-padding video-block-wrapper"> <div class="col video-box"> <div class="portada"> <img src="/sites/default/files/styles/diapositiva_1200x650/public/2023-07/portada-gratuito-grande_2.jpg?itok=8dBQYXT7" class="img-fluid" alt=""> <div class="field field--name-vo-youtube-video field--type-entity-reference field--label-visually_hidden"> <div class="field__label visually-hidden">Video de Youtube</div> <div class="field__item"><article class="media media--type-remote-video media--view-mode-diapositiva-1200x650"> <div class="field field--name-field-media-oembed-video field--type-string field--label-visually_hidden"> <div class="field__label visually-hidden">URL de Video remoto</div> <div class="field__item"><div class="modal micromodal-slide" id="modal-media-594-0-field-media-oembed-video" aria-hidden="true"> <div class="modal__overlay" tabindex="-1" data-micromodal-close> <div class="modal__container" role="dialog" aria-modal="true" aria-labelledby="modal-media-594-0-field-media-oembed-video-content"> <a class="modal__btn" data-micromodal-close aria-label="Close this dialog window">X</a> <main class="modal__content" id="modal-media-594-0-field-media-oembed-video-content"> <div class="videoWrapper"><iframe src="/media/oembed?url=https%3A//youtu.be/w-xb55iUKkg&amp;max_width=0&amp;max_height=0&amp;hash=QKMppvHS30J8GFtO-KJvYtW5HgNLuyXcSADWM5vCT3A" frameborder="0" allowtransparency="" class="media-oembed-content" title="Time Value of Money"></iframe></div> </main> </div> </div> </div> <div><a class="myButton" data-micromodal-trigger="modal-media-594-0-field-media-oembed-video"><span class="btn play-btn">.</span></a></div> </div> </div> </article> </div> </div> </div> </div> </section> </div> </div> <div class="field__item"> <div class="paragraph paragraph--type--text-only paragraph--view-mode--default" id="txonly-1156" style="background-color: ;border: solid px;border-color: #096ba0;border-radius: 5px;padding: 10px;"> <div class="clearfix text-formatted field field--name-to-text field--type-text-long field--label-visually_hidden"> <div class="field__label visually-hidden">Texto</div> <div class="field__item"><h2><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 48.45%;" data-ratio="48.45" data-b-token="b-1fcbee1b6fc" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img data-entity-uuid="6e78e462-f431-4d4c-ba13-4888fb6977b1" alt="Docker for Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" decoding="async" class="media__element b-lazy b-filter img-fluid" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/docker-for-drupal-portada.png?itok=5OK9TMIp" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="1063" height="515" typeof="foaf:Image" /></div></div> </h2> <h2><strong>Si no ves el video, puedes refrescar el navegador, presionando (Ctrl+Shift+R | Ctrl+F5 o Shift+F5), o abrirlo directamente desde el Canal de Youtube... <a href="https://youtu.be/w-xb55iUKkg" target="_blank">HAZ CLIC AQUI</a></strong></h2> <p>     Si estás trabajando con Drupal, en muchas ocasiones te verás en la necesidad de instalar y poner en marcha, en tu entorno local, proyectos que han sido creados previamente por otros desarrolladores o miembros de tu equipo de trabajo, para que puedas realizar la implementación de algunos cambios, analizar el código del código o simplemente realizar tareas de testing en un entorno seguro.</p> <p>     Tienes disponibles varios métodos de configuración para entornos locales <a href="https://www.drupaladicto.com/trabajando-con-servidores-locales">HACIENDO CLIC AQUÍ</a></p> <p>     Hoy te quiero mostrar, cómo trabajar en tu entorno local, basándonos en contenedores Docker y un proyecto existente de Drupal 9, para que puedas entender todos los pasos necesarios y activar cualquier proyectos sin la necesidad de invertir demasiado tiempo en el proceso.</p> <h2>   Activar un proyecto Drupal 9 existente utilizando Docker for Drupal</h2> <h3>     Requisitos:</h3> <p>        - Tener instalado Docker y Docker compose en tu entorno local. <a href="https://docs.docker.com/desktop/install/mac-install/">HAZ CLIC AQUI</a></p> <p>        - Tener los archivos del proyecto Drupal con el que vas a trabajar. Para descargar la estructura base vacía <a href="https://github.com/drupal-composer/drupal-project" target="_blank">HAZ CLIC AQUÍ</a></p> <p>        - Tener la base de datos del proyecto Drupal con el vas a trabajar</p> <p> </p> <h3>     Paso 1 - Descargar archivos servidor</h3> <p>     Antes de poder comenzar con el proceso de instalación del proyecto Drupal, necesitaremos poder ejecutar código PHP, acceder a nuestra base de datos por medio de Mysql y acceder a un servidor Apache o NGNIX.</p> <p>     La buena noticia, es que exite un repositorio, en el que podremos encontrar todo lo necesario, se llama DockerForDrupal, desarrollado por el equipo de Wodby.</p> <p>     Así que abriremos nuestra consola y, a continuación, clonaremos el respositorio, para tener disponibles todos los archivos:</p> <pre> git clone https://github.com/wodby/docker4drupal.git/ server</pre> <p>     Esto descargará todos los archivos en la carpeta server, y de esta manera, podremos copiar los archivos necesarios para cualquier proyecto de Drupal, sin la necesidad de tener que descargarlos nuevamente en el futuro.</p> <p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 27.33%;" data-ratio="27.33" data-b-token="b-02eb8e6d2e3" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img alt="Docker for Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" title="Docker for Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" decoding="async" class="media__element b-lazy b-filter img-fluid" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/file-635c56d557757.jpg?itok=_jmZ_y1J" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="1200" height="328" typeof="foaf:Image" /></div></div> <p>     Para que no tengamos ningún tipo de conflicto, una vez copiemos los archivos necesarios en cualquier proyecto de Drupal, eliminaremos el directorio <strong>.git </strong>y el archivo <strong>docker-compose.override.yml</strong></p> <p><strong>     </strong>Así que nos colocaremos dentro de la carpeta server y a continuación, ejecutaremos los siguientes comandos en nuestra consola:</p> <pre> sudo rm -rf .git</pre> <pre> sudo rm -f docker-compose.override.yml</pre> <p>     Con estos dos comandos habremos eliminado cualquier posibilidad de conflicto en el futuro.</p> <h3>     Paso 2 - Copiar los archivos desde el servidor hacia Drupal</h3> <p>     En este punto, lo próximo que necesitaremos realizar el la copia de todos los archivos ubicados en la carpeta server, hacia la carpeta raíz del nuestro proyecto Drupal, puedes hacerlo por consola o desde el explorador de archivos de windows, arrastrándolos.</p> <pre> sudo cp -R server/ drupal9</pre> <h3>     Paso 3 - Ajuste de configuración en el archivo .env</h3> <p>     Antes de poder comenzar a trabajar con los contenedores relacionados con nuestro proyecto Drupal, tendremos que explorar y modificar algunos ajustes, relacionados principalmente con el nombre del proyecto, la conexión con MySQL, entre otros.</p> <p>     Para ello, abriremos el archivo (.env), que veremos en nuestra carpeta raiz, al haber copiado los archivos desde la carpetar server; en él encontraremos todas las definiciones por defecto, paa trabajar con un proyecto Drupal, incluyendo el nombre del proyecto, datos de conexión al servidor mysql, entre otros.</p> <p>     Como la idea es trabajar con un proyecto que ya existe, deberíamos modificar algunos de estos datos, o simplemente, dejar los mismos y actualizar los datos de conexión en el archivo de Drupal llamado settings.php, dentro de la carpeta "<strong>web/sites/default/</strong>"</p> <pre> ### PROJECT SETTINGS PROJECT_NAME=drupal9_existente PROJECT_BASE_URL=drupal9_existente.docker.localhost PROJECT_PORT=8000 DB_NAME=drupal9_existente DB_USER=drupal9_existente DB_PASSWORD=drupal9_existente DB_ROOT_PASSWORD=password DB_HOST=mariadb DB_PORT=3306 DB_DRIVER=mysql</pre> <h3>     Paso 4 - Arranque y comprobación de contenedores Docker </h3> <p>     Si todos los pasos anteriores no han devuelto ningún error o si ya los hemos corregido, entonces, podremos poner en marcha todos los contenedores, para continuar con el proceso de instalación de Drupal.</p> <p>     El primer comando que tendremos que ejecutar para el arranque será el siguiente:</p> <pre> docker-compose up -d</pre> <p>     Si tienes instalado Make, también puedes utilizar este comando :</p> <pre> make up</pre> <p>     Si quieres saber qué es Make y cómo instalarlo, <a href="/snippet/como-instalar-make-en-ubuntu" target="_blank">HAZ CLIC AQUÍ</a></p> <p>     Esto se iniciará el proceso de activación de todos los cotenedores en segundo plano, para que podamos continuar en la misa ventana de nuestra consola, sin entrar en conflicto cada vez que ejecutemos código posteriormente.</p> <p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 14.08%;" data-ratio="14.08" data-b-token="b-37831a8a230" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img alt="Docker for Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" title="Docker for Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" decoding="async" class="media__element b-lazy b-filter img-fluid" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/file-635c57128fa05.jpg?itok=FcI9M39G" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="1200" height="169" typeof="foaf:Image" /></div></div> <h3> Paso 5 - Importación de la base de datos</h3> <p>     Ya tenemos todo lo necesario para que podamos acceder a nuestro proyecto de Drupal, los contenedores ya están funcionando, por lo que, si escribimos el dominio, configurado en el archivo .evn, dentro de nuesto navegador, lo siguiente que tendríamos que ver es nuesto proyecto funcionando, pero todavía no hemos importado la base de datos para que esto ocurra.</p> <p>     Para importar la base de datos dentro de nuestro contenedor y que podamos ver luego el proyecto, tendremos que acceder directamente dentro del contenedor adecuado, para eso, ejecutaremos el comando que nos devolverá el nombre y estatus de todos los contenedores:</p> <pre> docker ps</pre> <p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 10.54%;" data-ratio="10.54" data-b-token="b-b89961241a9" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img alt="Docker for Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" title="Docker for Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" decoding="async" class="media__element b-lazy b-filter img-fluid" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/file-635c574536ce4.png?itok=wOzYLsmD" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="1300" height="137" typeof="foaf:Image" /></div></div> <p>     A continuacióbn, buscaremos el Identificador único para el contenedor de Mysql, y luego escribiremos el siguiente comando, sustituyendo los datos necesarios:</p> <pre> docker exec -it ID_CONTENEDOR bash</pre> <p>     Con esto podremos acceder al interior del contenedor seleccionado, que en este caso será el encargado de gestionar nuestra base de datos y a continuación, podremos ejecutar cualquiera de los comando de mysql.</p> <p>     Para acceder al servidor Mysql y consultar, podremos ejecutar algo parecido al siguiente comando:</p> <pre> mysql -udrupal9_existente -pdrupal9_existente</pre> <p>     Con la anterior líneas, estaremos dentro de MySql y podremos ver el listado de bases de datos, de usuarios, permisos, etc.</p> <p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 22.83%;" data-ratio="22.83" data-b-token="b-070bb1b0575" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img alt="Docker for Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" title="Docker for Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" decoding="async" class="media__element b-lazy b-filter img-fluid" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/file-635c577450186.jpg?itok=1xFkNhyE" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="1200" height="274" typeof="foaf:Image" /></div></div> <p>     En nuestro caso, ya tenemos listo el archivo que vamos a importar, colocado dentro de la carpeta raíz de nuestro proyecto Drupal, por lo tanto, para accedere al contenedor y realizar la importación, bastará con ejecutar el siguiente comando, sustituyendo los datos por los correspondientes a tus propios contenedores:</p> <pre> docker exec -i f8e957b6b019 mysql -udrupal9_existente -pdrupal9_existente drupal9_existente &lt; backup_existente.sql</pre> <h3>   Ejecución de comandos con Composer y Drush</h3> <p>     Ya tenemos nuestro proyecto Drupal, listo para continuar trabajando, pero quizás necesitaremos realizar algunas actualizaciones, ya sea mediante el uso del gestor de paquetes Composer, o de la herramienta Drush.</p> <p>     En estos casos, el contenedor desde el cual tendremos que ejecutar ambas operaciones, será el encargado de php, por lo que buscaremos nuevamente el nombre, con el comando docker ps, y una vez lo sepamos, la operación será muy parecida:</p> <pre> docker exec -it ID_CONTENEDOR bash</pre> <p>     Y posteriormente, podremos ejecutar cualquiera de los comandos de Composer o Drush.</p> <p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 22.83%;" data-ratio="22.83" data-b-token="b-ddaafc7121e" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img alt="Docker for Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" title="Docker for Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" decoding="async" class="media__element b-lazy b-filter img-fluid" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/file-635c582015d08.jpg?itok=G8PrrnGv" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="1200" height="274" typeof="foaf:Image" /></div></div> <h3>     Posibles fallos durante el proceso:</h3> <p><em><strong>       Permisos de Docker</strong></em></p> <p>     Es posible que al ejecutar el comando para levantar los contenedores de Docker <em><strong>docker-compose up - d, </strong></em> la primera vez, te encuentres con un error relacionados con los permisos de ejecucion de los contenedores</p> <p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 21.75%;" data-ratio="21.75" data-b-token="b-eaafa5909b0" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img alt="Docker for Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" title="Docker for Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" decoding="async" class="media__element b-lazy b-filter img-fluid" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/file-635c584f96a34.jpg?itok=7BPbDgwL" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="1200" height="261" typeof="foaf:Image" /></div></div> <p>     Para solucionarlo, ejecuta el siguiente comando, ubicándote dentro de la carpeta en la que quieres levantar los contenedores:</p> <pre> sudo chmod 777 /var/run/docker.sock</pre> <p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 21.75%;" data-ratio="21.75" data-b-token="b-4df56ca7896" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img alt="Docker for Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" title="Docker for Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" decoding="async" class="media__element b-lazy b-filter img-fluid" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/file-635c587d4a4a4.jpg?itok=drL7I4ON" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="1200" height="261" typeof="foaf:Image" /></div></div> <p><em><strong>   Permisos en las carpetas</strong></em></p> <p><em><strong>     </strong></em>Aunque estemos trabajando con los archivos de un proyecto existente, al momento de trasladar esos archivos dentro de los contenedores, es posible que tengamos que volver a otorgar permisos de escritura y lectura a la carpeta root.</p> <p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 48.42%;" data-ratio="48.42" data-b-token="b-842a1d4cd1d" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img alt="Docker for Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" title="Docker for Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" decoding="async" class="media__element b-lazy b-filter img-fluid" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/file-635c58a502268.jpg?itok=123-mp8z" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="1200" height="581" typeof="foaf:Image" /></div></div> <p>     Para otorgar todos los permisos, nos colocaremos dentro de nuestra carpeta raiz y a continuación, ejecutaremos el comando siguiente:</p> <pre> sudo chmod -R 777 ./</pre> </div> </div> </div> </div> </div> <span class="field field--name-uid field--type-entity-reference field--label-hidden"><span lang="" about="/luis-alberto-mejia" typeof="schema:Person" property="schema:name" datatype="">webmaster</span></span> <span class="field field--name-created field--type-created field--label-hidden">Mié, 08/03/2023 - 18:13</span> Wed, 08 Mar 2023 17:13:50 +0000 webmaster 267 at https://drupaladicto.com Symfony | Entorno de desarrollo WSL2 en Windows https://drupaladicto.com/curso/entornos-locales/symfony-entorno-de-desarrollo-wsl2-en-windows <span class="field field--name-title field--type-string field--label-hidden">Symfony | Entorno de desarrollo WSL2 en Windows</span> <div class="field field--name-field-contenidos-cap-gratis field--type-entity-reference-revisions field--label-hidden field__items"> <div class="field__item"> <div class="paragraph paragraph--type--text-only paragraph--view-mode--default" id="txonly-1155" style="background-color: ;border: solid px;border-color: #096ba0;border-radius: 5px;padding: 10px;"> <div class="clearfix text-formatted field field--name-to-text field--type-text-long field--label-visually_hidden"> <div class="field__label visually-hidden">Texto</div> <div class="field__item"><p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 41.73%;" data-ratio="41.73" data-b-token="b-80c05e5581c" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img data-entity-uuid="1a1f6f20-173b-4bfb-b118-a70412542ebe" alt="Symfony | www.drupaladicto.com - Consultor especializado en Drupal y Symfony" decoding="async" class="media__element b-lazy b-filter img-fluid" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/symfony-portada.png?itok=1fArXJE_" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="1112" height="464" typeof="foaf:Image" /></div></div>   <p>   Ahora que ya sabemos <a href="https://www.drupaladicto.es/actualidad/como-instalar-drupal-9-usando-docker-en-windows-10-home">Cómo instalar una distribución Linux dentro de Windows 10 usando el WSL</a>, podemos pasar al siguiente nivel y explorar tantas opciones como nos hagan falta, para trabajar con cualquier proyecto, sin tener que cambiarnos de ordenador o trabajar con máquinas virtuales.</p> <p>     La idea es facilitarnos la vida y que podamos implementar todas las herramientas necesarias sin la necesidad de invertir demasiado tiempo en ello.</p> <p>     Por esta razón, hoy vamos a explicar cómo podremos configurar un entorno PHP para desarrollar un proyecto utilizando <a href="https://symfony.com/doc/current/index.html" target="_blank">Symfony</a>; uno de los Frameworks más potentes, robustos y seguros  que existen en el mercado.</p> <p><strong>     Aclaración antes de seguir</strong></p> <p>     Al momento de crear este artículo, existe <a href="https://github.com/microsoft/WSL/issues/4898">un conocido error</a> relacionado con el reloj en tiempo real con Ubuntu 20.04 y WSL2. Para evitar que surja este error, configuramos APT para congelar nuestra versión libc6 instalada a la de la distribución original emitiendo el siguiente comando:</p> <pre> sudo apt-mark hold libc6</pre> <p>     Tan pronto como hayamos ejecutado el anterior comando, podremos actualizar los paquetes de ubuntu ejecutando los siguiente:</p> <pre> sudo apt update</pre> <pre> sudo apt upgrade</pre> <p>     Lo próximo que instalemos son las dependencias centrales para ejecutar la plataforma eZ (y muchas otras aplicaciones Symfony):</p> <pre> sudo apt install composer php-xml php-intl php-gd php-curl php-fpm</pre> <p>     En la línea anterior, he omitido el servicio de base de datos para aclarar que la plataforma eZ es compatible con las bases de datos MySQL / MariaDB y PostgreSQL. ASí que podrás elegir lo que mejor se adapte a tus necesidades. En nuestro caso usaremos MariaDB para este tutorial. Instala el servidor MariaDB y la extensión PHP MySQL:</p> <pre> sudo apt install mariadb-server php-mysql</pre> <p>     Ya estamos listos para arrancar la instancia del servidor MariaDB e iniciar sesión como usuario root:</p> <pre> sudo service mysql start</pre> <pre> sudo mysql</pre> <p>     Vamos a añadir una base de datos para la plataforma eZ, Por lo que ejecutamos las siguientes declaraciones SQL:</p> <pre> CREATE DATABASE ezp; GRANT ALL ON ezp.* TO 'ezp'@'localhost' IDENTIFIED BY 'wsl2ezp'; FLUSH PRIVILEGES; EXIT;</pre> <p>     Y ahora comprobamos que podemos acceder a la base de datos:</p> <pre> mysql -uezp -pwsl2ezp ezp</pre> <p>     Ahora ya tenemos un entorno Linux con PHP, MariaDB y el administrador de paquetes Composer listo para funcionar:</p> <p> </p> <p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 34.47%;" data-ratio="34.47" data-b-token="b-648f1a924d1" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img loading="lazy" alt="comprobacion consola" decoding="async" class="media__element b-lazy b-filter img-fluid" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/comprobacion.png?itok=3-J-JoIr" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="882" height="304" typeof="foaf:Image" /></div></div> <p>     Ya que vamos a utilizar Symfony Encore para gestionar los activos de front-end, instalaremos el administrador de paquetes Yarn desde el repositorio del proyecto. De esta forma también instalará Node.js como dependencia:</p> <pre> curl -sS https://dl.yarnpkg.com/debian/pubkey.gpg | sudo apt-key add - echo "deb https://dl.yarnpkg.com/debian/ stable main" | sudo tee /etc/apt/sources.list.d/yarn.list sudo apt update sudo apt install yarn</pre> <h3>     Instalando el CLI de Symfony</h3> <p>     A estas alturas, puede que hayas notado que falta en el procedimiento de instalación anterior es la A en LAMP y la E en LEMP. En lenguaje sencillo: nuestra pila no tiene un servidor web instalado. Tradicionalmente, una pila PHP ha incluido un servidor web separado. Un servidor HTTP completo sigue siendo para instalaciones de producción, pero como estamos en desarrollo utilizaremos una opción más simple: Symfony Local Web Server</p> <p>     Symfony CLI es una aplicación de línea de comandos independiente que podremos instalar desde nuestra terminal WSL. Recuerda seguir las instrucciones de Linux, NO las de Windows:</p> <pre> wget https://get.symfony.com/cli/installer -O - | bash</pre> <p>     El código anterior lo instalará en nuestra carpeta de usuario, pero  podremos hacerlo disponible de forma global si ejecutamos el siguiente código, cambiando el NOMBRE DEL USUARIO por el tuyo:</p> <pre> sudo mv /home/nombre_usuario/.symfony/bin/symfony /usr/local/bin/symfony</pre> <p>     Ahora podemos verificar que nuestra pila está funcionando creando una nueva aplicación Symfony hello world y ejecutando el servidor web:</p> <pre> symfony new hola-mundo cd hola-mundo symfony serve</pre> <p>     Ha llegado el momento de abrir una ventana del navegador en <strong>http: // localhost: 8000 / </strong>para ver la aplicación en ejecución. La primera vez que lo ejecutes, es posible que Windows te pregunte si este tráfico está permitido. Ahora debería tener una aplicación Symfony básica ejecutándose en Windows usando WSL2 como se muestra en la captura de pantalla a continuación.</p> <p> </p> <p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 45.77%;" data-ratio="45.77" data-b-token="b-d41f0f03931" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img loading="lazy" alt="symfony funcionando correctamente" decoding="async" class="media__element b-lazy b-filter img-fluid" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/funcionando_symfony.png?itok=tFPN5lRW" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="1300" height="595" typeof="foaf:Image" /></div></div> <p>     Para obtener más detalles sobre cómo configurar TLS, múltiples versiones de PHP, etc., diríjase a los <a href="https://symfony.com/doc/current/setup/symfony_server.html" target="_blank">documentos de Symfony</a>.</p> <h3>     Instalación de la Plataforma eZ y acceso a archivos</h3> <p>     El siguiente paso es instalar y ejecutar una aplicación Symfony completa. Esto funciona como en cualquier entorno Linux (¡porque es uno!). Así que vamos a <a href="https://doc.ezplatform.com/en/latest/getting_started/install_ez_platform/" target="_blank">instalar una copia de la plataforma eZ </a> y para ello utilizaremos. Éste se encargará de clonar los archivos desde el <a href="https://github.com/ezsystems/ezplatform" target="_blank">repositorio</a>, verificará por nosotros <a href="https://github.com/ezsystems/ezplatform/releases" target="_blank" title="">las actualizaciones disponibles</a> y a continuación instalar los paquetes necesarios usando:</p> <pre> composer create-project ezsystems/ezplatform ezplatform ^3 cd ezplatform</pre> <p>     Lo siguiente será instalar nuestra base de datos y para ello, necesitamos definir la configuración de la base de datos y ejecutar el instalador:</p> <pre> echo "DATABASE_URL=mysql://ezp:wsl2ezp@127.0.0.1:3306/ezp?serverVersion=10.3" &gt; .env.local composer run-script ezplatform-install</pre> <p>Cuando se haya completado el proceso de instalación,  podremos ingresar al directorio del proyecto e iniciar el servidor web Symfony:</p> <pre> symfony serve</pre> <p>     El resultado mostrará que el servidor web Symfony detecta y usa la copia instalada de PHP-FPM:</p> <p>     Ahora, si abrimos un navegador (en Windows) y nos dirigimos a http: // localhost: 8000 /, podremos ver la aplicación en ejecución. Para acceder a los archivos desde Windows, puede ejecutar el siguiente comando para abrir una ventana del Explorador de Windows en su directorio de trabajo actual:</p> <pre> explorer.exe .</pre> <p>     Desde aquí, podrás recoger las cosas y usar cualquier IDE en Windows (¡o incluso notepad.exe!) Que necesites usar para tu desarrollo.</p> </div> </div> </div> </div> </div> <span class="field field--name-uid field--type-entity-reference field--label-hidden"><span lang="" about="/luis-alberto-mejia" typeof="schema:Person" property="schema:name" datatype="">webmaster</span></span> <span class="field field--name-created field--type-created field--label-hidden">Mié, 08/03/2023 - 18:11</span> Wed, 08 Mar 2023 17:11:11 +0000 webmaster 266 at https://drupaladicto.com Configurar un entorno de desarrollo PHP para Symfony con Windows y WSL2 https://drupaladicto.com/actualidad/configurar-un-entorno-de-desarrollo-php-para-symfony-con-windows-y-wsl2 <span class="field field--name-title field--type-string field--label-hidden">Configurar un entorno de desarrollo PHP para Symfony con Windows y WSL2</span> <span class="field field--name-uid field--type-entity-reference field--label-hidden"><span lang="" about="/luis-alberto-mejia" typeof="schema:Person" property="schema:name" datatype="">webmaster</span></span> <span class="field field--name-created field--type-created field--label-hidden">Mié, 08/03/2023 - 18:06</span> <div class="field field--name-field-contenidos-post field--type-entity-reference-revisions field--label-visually_hidden"> <div class="field__label visually-hidden">Contenidos</div> <div class="field__items"> <div class="field__item"> <div class="paragraph paragraph--type--text-only paragraph--view-mode--default" id="txonly-1134" style="background-color: ;border: solid px;border-color: #096ba0;border-radius: 5px;padding: 10px;"> <div class="clearfix text-formatted field field--name-to-text field--type-text-long field--label-visually_hidden"> <div class="field__label visually-hidden">Texto</div> <div class="field__item"><p>     Ahora que ya sabemos <a href="/actualidad/como-instalar-drupal-9-usando-docker-en-windows-10-home">Cómo instalar una distribución Linux dentro de Windows 10 usando el WSL</a>, podemos pasar al siguiente nivel y explorar tantas opciones como nos hagan falta, para trabajar con cualquier proyecto, sin tener que cambiarnos de ordenador o trabajar con máquinas virtuales.</p> <p>     La idea es facilitarnos la vida y que podamos implementar todas las herramientas necesarias sin la necesidad de invertir demasiado tiempo en ello.</p> <p>     Por esta razón, hoy vamos a explicar cómo podremos configurar un entorno PHP para desarrollar un proyecto utilizando <a href="https://symfony.com/doc/current/index.html" target="_blank">Symfony</a>; uno de los Frameworks más potentes, robustos y seguros  que existen en el mercado.</p> <p><strong>     Aclaración antes de seguir</strong></p> <p>     Al momento de crear este artículo, existe <a href="https://github.com/microsoft/WSL/issues/4898">un conocido error</a> relacionado con el reloj en tiempo real con Ubuntu 20.04 y WSL2. Para evitar que surja este error, configuramos APT para congelar nuestra versión libc6 instalada a la de la distribución original emitiendo el siguiente comando:</p> <pre> sudo apt-mark hold libc6</pre> <p>     Tan pronto como hayamos ejecutado el anterior comando, podremos actualizar los paquetes de ubuntu ejecutando los siguiente:</p> <pre> sudo apt update</pre> <pre> sudo apt upgrade</pre> <p>     Lo próximo que instalemos son las dependencias centrales para ejecutar la plataforma eZ (y muchas otras aplicaciones Symfony):</p> <pre> sudo apt install composer php-xml php-intl php-gd php-curl php-fpm</pre> <p>     En la línea anterior, he omitido el servicio de base de datos para aclarar que la plataforma eZ es compatible con las bases de datos MySQL / MariaDB y PostgreSQL. ASí que podrás elegir lo que mejor se adapte a tus necesidades. En nuestro caso usaremos MariaDB para este tutorial. Instala el servidor MariaDB y la extensión PHP MySQL:</p> <pre> sudo apt install mariadb-server php-mysql</pre> <p>     Ya estamos listos para arrancar la instancia del servidor MariaDB e iniciar sesión como usuario root:</p> <pre> sudo service mysql start</pre> <pre> sudo mysql</pre> <p>     Vamos a añadir una base de datos para la plataforma eZ, Por lo que ejecutamos las siguientes declaraciones SQL:</p> <pre> CREATE DATABASE ezp; GRANT ALL ON ezp.* TO 'ezp'@'localhost' IDENTIFIED BY 'wsl2ezp'; FLUSH PRIVILEGES; EXIT;</pre> <p>     Y ahora comprobamos que podemos acceder a la base de datos:</p> <pre> mysql -uezp -pwsl2ezp ezp</pre> <p>     Ahora ya tenemos un entorno Linux con PHP, MariaDB y el administrador de paquetes Composer listo para funcionar:</p> <p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 34.47%;" data-ratio="34.47" data-b-token="b-648f1a924d1" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img class="img-fluid media__element b-lazy b-filter" data-entity-uuid="cb53b28d-5595-4943-8e59-401e09a5793d" data-responsive-image-style="" alt="comprobacion consola" decoding="async" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/comprobacion.png?itok=3-J-JoIr" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="882" height="304" typeof="foaf:Image" /></div></div> <p>     Ya que vamos a utilizar Symfony Encore para gestionar los activos de front-end, instalaremos el administrador de paquetes Yarn desde el repositorio del proyecto. De esta forma también instalará Node.js como dependencia:</p> <pre> curl -sS https://dl.yarnpkg.com/debian/pubkey.gpg | sudo apt-key add - echo "deb https://dl.yarnpkg.com/debian/ stable main" | sudo tee /etc/apt/sources.list.d/yarn.list sudo apt update sudo apt install yarn</pre> <h3>     Instalando el CLI de Symfony</h3> <p>     A estas alturas, puede que hayas notado que falta en el procedimiento de instalación anterior es la A en LAMP y la E en LEMP. En lenguaje sencillo: nuestra pila no tiene un servidor web instalado. Tradicionalmente, una pila PHP ha incluido un servidor web separado. Un servidor HTTP completo sigue siendo para instalaciones de producción, pero como estamos en desarrollo utilizaremos una opción más simple: Symfony Local Web Server</p> <p>     Symfony CLI es una aplicación de línea de comandos independiente que podremos instalar desde nuestra terminal WSL. Recuerda seguir las instrucciones de Linux, NO las de Windows:</p> <pre> wget https://get.symfony.com/cli/installer -O - | bash</pre> <p>     El código anterior lo instalará en nuestra carpeta de usuario, pero  podremos hacerlo disponible de forma global si ejecutamos el siguiente código, cambiando el NOMBRE DEL USUARIO por el tuyo:</p> <pre> sudo mv /home/nombre_usuario/.symfony/bin/symfony /usr/local/bin/symfony</pre> <p>     Ahora podemos verificar que nuestra pila está funcionando creando una nueva aplicación Symfony hello world y ejecutando el servidor web:</p> <pre> symfony new hola-mundo cd hola-mundo symfony serve</pre> <p>     Ha llegado el momento de abrir una ventana del navegador en <strong>http: // localhost: 8000 / </strong>para ver la aplicación en ejecución. La primera vez que lo ejecutes, es posible que Windows te pregunte si este tráfico está permitido. Ahora debería tener una aplicación Symfony básica ejecutándose en Windows usando WSL2 como se muestra en la captura de pantalla a continuación.</p> <p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 45.77%;" data-ratio="45.77" data-b-token="b-d41f0f03931" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img class="img-fluid media__element b-lazy b-filter" data-entity-uuid="e3374cfa-56c1-43dd-b856-9de3b933077a" data-responsive-image-style="" alt="symfony funcionando correctamente" decoding="async" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/funcionando_symfony.png?itok=tFPN5lRW" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="1300" height="595" typeof="foaf:Image" /></div></div> <p>     Para obtener más detalles sobre cómo configurar TLS, múltiples versiones de PHP, etc., diríjase a los <a href="https://symfony.com/doc/current/setup/symfony_server.html" target="_blank">documentos de Symfony</a>.</p> <h3>     Instalación de la Plataforma eZ y acceso a archivos</h3> <p>     El siguiente paso es instalar y ejecutar una aplicación Symfony completa. Esto funciona como en cualquier entorno Linux (¡porque es uno!). Así que vamos a <a href="https://doc.ezplatform.com/en/latest/getting_started/install_ez_platform/" target="_blank">instalar una copia de la plataforma eZ </a> y para ello utilizaremos. Éste se encargará de clonar los archivos desde el <a href="https://github.com/ezsystems/ezplatform" target="_blank">repositorio</a>, verificará por nosotros <a href="https://github.com/ezsystems/ezplatform/releases" target="_blank" title="">las actualizaciones disponibles</a> y a continuación instalar los paquetes necesarios usando:</p> <pre> composer create-project ezsystems/ezplatform ezplatform ^3 cd ezplatform</pre> <p>     Lo siguiente será instalar nuestra base de datos y para ello, necesitamos definir la configuración de la base de datos y ejecutar el instalador:</p> <pre> echo "DATABASE_URL=mysql://ezp:wsl2ezp@127.0.0.1:3306/ezp?serverVersion=10.3" &gt; .env.local composer run-script ezplatform-install</pre> <p>Cuando se haya completado el proceso de instalación,  podremos ingresar al directorio del proyecto e iniciar el servidor web Symfony:</p> <pre> symfony serve</pre> <p>     El resultado mostrará que el servidor web Symfony detecta y usa la copia instalada de PHP-FPM:</p> <p>     Ahora, si abrimos un navegador (en Windows) y nos dirigimos a http: // localhost: 8000 /, podremos ver la aplicación en ejecución. Para acceder a los archivos desde Windows, puede ejecutar el siguiente comando para abrir una ventana del Explorador de Windows en su directorio de trabajo actual:</p> <pre> explorer.exe .</pre> <p>     Desde aquí, podrás recoger las cosas y usar cualquier IDE en Windows (¡o incluso notepad.exe!) Que necesites usar para tu desarrollo.</p> </div> </div> </div> </div> </div> </div> <div class="field field--name-field-categoria-post field--type-entity-reference field--label-above"> <div class="field__label">Categoría</div> <div class="field__items"> <div class="field__item"><a href="/categoria/symfony" hreflang="es">symfony</a></div> <div class="field__item"><a href="/categoria/servidor" hreflang="es">servidor</a></div> <div class="field__item"><a href="/categoria/lamp" hreflang="es">lamp</a></div> <div class="field__item"><a href="/categoria/apache" hreflang="es">apache</a></div> <div class="field__item"><a href="/categoria/php" hreflang="es">php</a></div> <div class="field__item"><a href="/categoria/mysql" hreflang="es">mysql</a></div> <div class="field__item"><a href="/categoria/server" hreflang="es">server</a></div> <div class="field__item"><a href="/categoria/local" hreflang="es">local</a></div> <div class="field__item"><a href="/categoria/desarrollo" hreflang="es">desarrollo</a></div> <div class="field__item"><a href="/categoria/development" hreflang="es">development</a></div> <div class="field__item"><a href="/categoria/entornos" hreflang="es">entornos</a></div> <div class="field__item"><a href="/categoria/linux" hreflang="es">linux</a></div> <div class="field__item"><a href="/categoria/console" hreflang="es">console</a></div> <div class="field__item"><a href="/categoria/consola" hreflang="es">consola</a></div> <div class="field__item"><a href="/categoria/ubuntu" hreflang="es">ubuntu</a></div> </div> </div> Wed, 08 Mar 2023 17:06:43 +0000 webmaster 265 at https://drupaladicto.com Node.js en (WSL2) | Instalación con Windows 11 https://drupaladicto.com/curso/entornos-locales/nodejs-en-wsl2-instalacion-con-windows-11 <span class="field field--name-title field--type-string field--label-hidden">Node.js en (WSL2) | Instalación con Windows 11</span> <div class="field field--name-field-contenidos-cap-gratis field--type-entity-reference-revisions field--label-hidden field__items"> <div class="field__item"> <style>#video-only-948 .play-btn:hover::after { border-left: 15px solid #1fd7d9; transform: scale(20); border-left: 15px solid #fff; } #video-only-948 .play-btn::before { border: 5px solid #1fd7d9; } #video-only-948 .play-btn { background: radial-gradient(#1fd7d9 50%, rgba(66, 109, 202, 0.4) 52%); }</style> <div class="paragraph paragraph--type--video-only paragraph--view-mode--default" id="vol-948"> <section id="video-only-948" class="about area-padding video-block-wrapper"> <div class="col video-box"> <div class="portada"> <img src="/sites/default/files/styles/diapositiva_1200x650/public/2023-07/portada-gratuito-grande_2.jpg?itok=8dBQYXT7" class="img-fluid" alt=""> <div class="field field--name-vo-youtube-video field--type-entity-reference field--label-visually_hidden"> <div class="field__label visually-hidden">Video de Youtube</div> <div class="field__item"><article class="media media--type-remote-video media--view-mode-diapositiva-1200x650"> <div class="field field--name-field-media-oembed-video field--type-string field--label-visually_hidden"> <div class="field__label visually-hidden">URL de Video remoto</div> <div class="field__item"><div class="modal micromodal-slide" id="modal-media-669-0-field-media-oembed-video" aria-hidden="true"> <div class="modal__overlay" tabindex="-1" data-micromodal-close> <div class="modal__container" role="dialog" aria-modal="true" aria-labelledby="modal-media-669-0-field-media-oembed-video-content"> <a class="modal__btn" data-micromodal-close aria-label="Close this dialog window">X</a> <main class="modal__content" id="modal-media-669-0-field-media-oembed-video-content"> <div class="videoWrapper"><iframe src="/media/oembed?url=https%3A//youtu.be/DPGaNJ6j-ts&amp;max_width=0&amp;max_height=0&amp;hash=xq7VwtOUDpw2fup9i4A3mBOiVAefTPK10JfDu2DOs1M" frameborder="0" allowtransparency="" class="media-oembed-content" title="Time Value of Money"></iframe></div> </main> </div> </div> </div> <div><a class="myButton" data-micromodal-trigger="modal-media-669-0-field-media-oembed-video"><span class="btn play-btn">.</span></a></div> </div> </div> </article> </div> </div> </div> </div> </section> </div> </div> <div class="field__item"> <div class="paragraph paragraph--type--text-only paragraph--view-mode--default" id="txonly-1154" style="background-color: ;border: solid px;border-color: #096ba0;border-radius: 5px;padding: 10px;"> <div class="clearfix text-formatted field field--name-to-text field--type-text-long field--label-visually_hidden"> <div class="field__label visually-hidden">Texto</div> <div class="field__item"><p>      Aquí en <strong>drupaladicto.com</strong> nos gusta facilitar al máximo, todo lo relacionado con el desarrollo web, basándonos en Drupal, pero también en las diferentes herramientas complementarias, para que nuestro desarrollo pueda realizarse de forma optimizada, y adecuada según la necesidad de cada proyecto.</p> <p>     Una de nuestras opciones preferidas, es el uso del subsistema para Windows, llamado WSL2, ya que nos permite interactuar tanto en Linux como en Windows, sin la necesidad de instalar máquinas virtuales, como por ejemplo <a href="https://www.oracle.com/emea/virtualization/solutions/try-oracle-vm-virtualbox/?source=:ad:pas:go:dg:a_emea:71700000086137880-58700007342953622-p65823631294:RC_WWMK201210P00009C0001:&amp;SC=:ad:pas:go:dg:a_emea::RC_WWMK201210P00009C0001::&amp;gclid=CjwKCAiAxJSPBhAoEiwAeO_fP6hvIYL67KsdjWwhqim9f4uCEj-jrjnBCQGG0XE_XpqwsDKixl5DQRoChbsQAvD_BwE&amp;gclsrc=aw.ds" target="_blank">VirtualBox</a>, cuya configuración y espacio necesarios para ejecutarse, muchas veces, dificultan nuestras actividades, en lugar de facilitarnos la vida.</p> <p>     Por esta razón, hoy aprenderemos a instalar y configurar el entorno de ejecución para JavaScript Node.js y los gestores de paquetes NVM ( Node Version Manager) y (NPM) (Node Package Manager), utilizando la distribución de Linux, Ubuntu 20.04 con WSL2 en un entorno Windows 11.</p> <p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 65.76%;" data-ratio="65.76" data-b-token="b-2a7d40ffb61" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img data-entity-uuid="4c87a379-51f8-4548-adeb-1c4ceb5e1b74" alt="Node JS | www.drupaladicto.com - Consultor especializado en drupal y symfony" decoding="async" class="media__element b-lazy b-filter img-fluid" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/node-portada.png?itok=19-Y-PuE" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="885" height="582" typeof="foaf:Image" /></div></div> <p>     Seguiremos los pasos de instalación publicados en la documentación de la <a href="https://docs.microsoft.com/es-es/windows/dev-environment/javascript/nodejs-on-wsl" target="_blank">Página Oficial de Microsoft</a>, que nos menciona el siguiente detalle a tomar en cuenta:</p> <p>     "Además de elegir si se desea realizar la instalación en Windows o WSL, al instalar Node.js es preciso elegir más opciones. Se recomienda usar un administrador de versiones, ya que las versiones cambian con mucha rapidez. Es probable que tenga que cambiar de versión de Node.js en función de las necesidades de los distintos proyectos en los que se trabaje. El administrador de versiones de Node, más comúnmente denominado nvm, es la forma más habitual de instalar varias versiones de Node.js.</p> <p>     Siempre se recomienda quitar cualquier instalación existente de Node.js o npm del sistema operativo antes de instalar un administrador de versiones, ya que los distintos tipos de instalación pueden provocar conflictos extraños y confusos."</p> <h2 id="install-nvm-nodejs-and-npm">Instalación de nvm, node.js y npm</h2> <p>  <strong>   Paso 1 : </strong>Abrir consola e iniciar sesión con nuestro usuario NO_ROOT, si no sabes, <a href="/actualidad/como-instalar-lamp-usando-wsl2-en-windows-10-1era-parte" target="_blank">haz clic aquí</a></p> <p>    <strong> Paso 2 :</strong> Instala cURL (una herramienta que se usa para descargar contenido de Internet en la línea de comandos) con: </p> <pre> sudo apt-get install curl</pre> <p>     <strong>Paso 3 :</strong> Instala nvm con: </p> <pre> curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.0/install.sh | bash</pre> <p>     <strong>NOTA :</strong> En el momento de redactar este artículo, NVM v0.39.0 es la versión más reciente disponible. Puedes consultar la <a data-linktype="external" href="https://github.com/nvm-sh/nvm">página del proyecto de GitHub para obtener la última versión de NVM</a> y ajustar el comando anterior para incluir la versión más reciente.</p> <p>     <strong>Paso 4 :</strong> Para verificar la instalación, escribe: command <strong>-v nvm</strong><strong>...</strong> esto debería devolver "nvm"; si recibes "No se encuentra el comando" o ninguna respuesta, cierra el terminal actual, vuelve a abrirlo e inténtalo de nuevo. <a data-linktype="external" href="https://github.com/nvm-sh/nvm">Obtén más información en el repositorio de GitHub de nvm</a>.</p> <p>     <strong>Paso 5 :</strong> Enumera qué versiones de Node están instaladas actualmente (en este momento no debe haber ninguna):</p> <pre> nvm ls</pre> <p>     <strong>Paso 6 : </strong>Instale las versiones de LTS actual y estable de Node.js. En un paso posterior, aprenderá a cambiar entre las versiones activas de Node.js con un comando <strong>nvm</strong>.</p> <ul><li>Instale la versión LTS estable actual de Node.js (recomendada para aplicaciones de producción): <pre> nvm install --lts</pre> </li> <li>Instale la versión actual de Node.js (para probar las características y mejoras de Node.js más recientes, pero con más probabilidad de presentar problemas): <pre> nvm install node</pre> </li> </ul><p>     <strong>Paso 7 :</strong> Enumera qué versiones de Node están instaladas: <strong>nvm ls...</strong> ahora deberías ver las dos versiones que acabas de instalar.</p> <p>     <strong>Paso 8 :</strong> Comprueba que Node.js está instalado y la versión predeterminada actualmente con: node --version. Después, comprueba que también tienes npm, con: </p> <pre> npm --version</pre> <p>     (También puedes usar which node o which npm para ver la ruta de acceso utilizada para las versiones predeterminadas).</p> <p>     <strong>Paso 9 :</strong> Para cambiar la versión de Node.js que deseas usar para un proyecto, crea un directorio de proyecto <strong>mkdir NodeTest</strong>, escribe el directorio <strong>cd NodeTest</strong> y, a continuación, escribe <strong>nvm use node</strong>, para cambiar a la versión actual, o bien <strong>nvm use --lts</strong> para cambiar a la versión de LTS. También puedes usar el número específico de cualquier versión adicional que hayas instalado, como nvm use v8.2.1. (Para enumerar todas las versiones de Node.js disponibles, usa el comando: <strong>nvm ls-remote</strong>).</p> <p><strong>     Si usas NVM para instalar Node.js y NPM, no es necesario usar el comando SUDO para instalar nuevos paquetes.</strong></p> </div> </div> </div> </div> </div> <span class="field field--name-uid field--type-entity-reference field--label-hidden"><span lang="" about="/luis-alberto-mejia" typeof="schema:Person" property="schema:name" datatype="">webmaster</span></span> <span class="field field--name-created field--type-created field--label-hidden">Mié, 08/03/2023 - 18:04</span> Wed, 08 Mar 2023 17:04:09 +0000 webmaster 264 at https://drupaladicto.com Cómo Instalar LAMP usando WSL2 en Windows 10 (1era Parte) https://drupaladicto.com/actualidad/como-instalar-lamp-usando-wsl2-en-windows-10-1era-parte <span class="field field--name-title field--type-string field--label-hidden">Cómo Instalar LAMP usando WSL2 en Windows 10 (1era Parte)</span> <span class="field field--name-uid field--type-entity-reference field--label-hidden"><span lang="" about="/luis-alberto-mejia" typeof="schema:Person" property="schema:name" datatype="">webmaster</span></span> <span class="field field--name-created field--type-created field--label-hidden">Mié, 08/03/2023 - 17:48</span> <div class="field field--name-field-contenidos-post field--type-entity-reference-revisions field--label-visually_hidden"> <div class="field__label visually-hidden">Contenidos</div> <div class="field__items"> <div class="field__item"> <style>#video-only-1019 .play-btn:hover::after { border-left: 15px solid #1fd7d9; transform: scale(20); border-left: 15px solid #fff; } #video-only-1019 .play-btn::before { border: 5px solid #1fd7d9; } #video-only-1019 .play-btn { background: radial-gradient(#1fd7d9 50%, rgba(66, 109, 202, 0.4) 52%); }</style> <div class="paragraph paragraph--type--video-only paragraph--view-mode--default" id="vol-1019"> <section id="video-only-1019" class="about area-padding video-block-wrapper"> <div class="col video-box"> <div class="portada"> <img src="/sites/default/files/styles/diapositiva_1200x650/public/2023-07/portada-post.jpg?itok=kSR2Q5ei" class="img-fluid" alt=""> <div class="field field--name-vo-youtube-video field--type-entity-reference field--label-visually_hidden"> <div class="field__label visually-hidden">Video de Youtube</div> <div class="field__item"><article class="media media--type-remote-video media--view-mode-diapositiva-1200x650"> <div class="field field--name-field-media-oembed-video field--type-string field--label-visually_hidden"> <div class="field__label visually-hidden">URL de Video remoto</div> <div class="field__item"><div class="modal micromodal-slide" id="modal-media-726-0-field-media-oembed-video" aria-hidden="true"> <div class="modal__overlay" tabindex="-1" data-micromodal-close> <div class="modal__container" role="dialog" aria-modal="true" aria-labelledby="modal-media-726-0-field-media-oembed-video-content"> <a class="modal__btn" data-micromodal-close aria-label="Close this dialog window">X</a> <main class="modal__content" id="modal-media-726-0-field-media-oembed-video-content"> <div class="videoWrapper"><iframe src="/media/oembed?url=https%3A//youtu.be/jiyN-qhYPRU&amp;max_width=0&amp;max_height=0&amp;hash=AIPM3z7Qnt9uX_61Mdg-XWYw0-Trx622QL9gzPRGc5w" frameborder="0" allowtransparency="" class="media-oembed-content" title="Time Value of Money"></iframe></div> </main> </div> </div> </div> <div><a class="myButton" data-micromodal-trigger="modal-media-726-0-field-media-oembed-video"><span class="btn play-btn">.</span></a></div> </div> </div> </article> </div> </div> </div> </div> </section> </div> </div> <div class="field__item"> <div class="paragraph paragraph--type--text-only paragraph--view-mode--default" id="txonly-1130" style="background-color: ;border: solid px;border-color: #096ba0;border-radius: 5px;padding: 10px;"> <div class="clearfix text-formatted field field--name-to-text field--type-text-long field--label-visually_hidden"> <div class="field__label visually-hidden">Texto</div> <div class="field__item"><h2><strong>Si no ves el video, puedes refrescar el navegador, presionando (Ctrl+Shift+R | Ctrl+F5 o Shift+F5), o abrirlo directamente desde el Canal de Youtube... <a href="https://youtu.be/jiyN-qhYPRU" target="_blank">HAZ CLIC AQUI</a></strong></h2> <p>      Antes de trabajar en cualquier proyecto web, deberíamos contar con un entorno completo, que incluya todo lo necesario para que nuestra aplicación funcione correctamente, además de ofrecernos un lugar estable donde podamos realizar todo tipo de pruebas y procedimientos.</p> <p>     Aunque ya hemos explicado en otro artículo todo lo que necesitas saber sobre <a href="/actualidad/como-instalar-drupal-9-usando-docker-en-windows-10-home" hreflang="es">Cómo instalar Drupal 9 usando Docker en Windows 10 Home</a>, hoy te voy a contar cómo realizar la instalación completa de un servidor Linux que incluya, además, el Apache, Mysql y PHP, con la respectiva configuración del dominio para que puedas instalar Drupal en tu servidor local.</p> <h2>   Cómo Instalar LAMP usando WSL2 en Windows 10</h2> <h3>      Paso 1 Instalación y configuración de WSL2 en Windows</h3> <p>          Para no repetirme, puedes leer todo el proceso de instalación y configuración del WSL2 para Windows 10, en el artículo <a href="/actualidad/como-instalar-drupal-9-usando-docker-en-windows-10-home" target="_blank">Cómo instalar Drupal 9 usando Docker en Windows 10 Home (1era Parte)</a>, y una vez hayas realizado la instalación podrás continuar con el siguiente paso.</p> <p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 45.34%;" data-ratio="45.34" data-b-token="b-0b95210bad3" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img class="img-fluid media__element b-lazy b-filter" data-entity-uuid="d6a8775f-8dcd-42eb-8b55-6393b45e344b" data-responsive-image-style="" alt="wsl2 - www.drupaladicto.org Formacion especializada en drupal y symfony - roles permisos y usuarios" decoding="async" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/distribucion_linux.gif?itok=fzlqNivS" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="783" height="355" typeof="foaf:Image" /></div></div> <p>          Además, antes de continuar, te recomiendo instalar la nueva terminal de Windows 10, para que puedas realizar operaciones simultáneas usando diferentes pestañas, te cuento cómo hacerlo en este artículo <a href="/actualidad/instalacion-y-configuracion-de-terminal-windows">Instalación y configuración de Terminal Windows</a></p> <p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div data-b-token="b-7b90b4fd003" class="media media--blazy media--image media--ratio media--ratio--32 is-b-loading"><img class="img-fluid media__element b-lazy b-filter" data-entity-uuid="52205fc4-4541-40a7-a0a4-da01260ccd16" data-responsive-image-style="" alt="windows terminal - www.drupaladicto.org Formacion especializada en drupal y symfony - roles permisos y usuarios" decoding="async" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/terminal.png?itok=Scuc5acM" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="600" height="400" typeof="foaf:Image" /></div></div> <p>     Ahora, antes de continuar, debe saber que puede omitir casi todos los pasos a continuación y simplemente hacer: <strong>sudo apt install lamp-server ^ phpmyadmin</strong>. Sin embargo, yo intenté hacerlo de esta forma y me dio varios errores, por lo que, en mi opinión recomiendo la opción "Larga", que además te dará control total sobre tu servidor y servicios instalados. </p> <h3><strong>      Paso 2 - crear un usuario No Root para la ejecución del código:</strong></h3> <p>          El usuario <strong>root</strong> es el usuario administrativo en un entorno Linux que tiene privilegios muy amplios. Debido a su inmenso poder, no se recomienda usarlo de forma regular. </p> <p>          El siguiente paso es configurar una cuenta de usuario alternativa, con un alcance de influencia reducido para el trabajo diario. Y podremos usar el la opción SUDO, cuando necesitemos permisos especiales sin tener que cambiar de usuario.</p> <p>          Con el siguiente código, voy a crear un usuario nuevo, que no será root, y que utilizaremos de aquí en adelante para el resto de la configuración.</p> <p>          Como por defecto en la instalación de ubuntu hemos creado el usuario root, ejecutaremos el siguiente comando con el prefijo sudo, y una vez complementada la información del nuevo usuario, que si no quieres rellenar la info puedes presionar ENTER en cada pregunta, como he hecho para este ejemplo.</p> <p>          Luego abriremos otra pestaña en la terminal de windows, si no la tienes instalada aprende cómo hacerlo en <a href="/actualidad/instalacion-y-configuracion-de-terminal-windows" target="_blank">Instalación y configuración de Terminal Windows</a>,  para no perder, de momento los accesos como root y luego continuaremos con el procedimiento:</p> <pre> adduser noroot_user</pre> <p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 56.77%;" data-ratio="56.77" data-b-token="b-e013dff78a7" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img class="img-fluid media__element b-lazy b-filter" data-entity-uuid="ed0353e9-8b97-4f96-b226-19f9c83d2a72" data-responsive-image-style="" alt="docker - www.drupaladicto.org Formacion especializada en drupal y symfony - roles permisos y usuarios" decoding="async" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/crear_usuario_no_root.png?itok=WLfVBKrX" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="620" height="352" typeof="foaf:Image" /></div></div> <p>          Una vez creado el nuevo usuario, abriremos la nueva pestaña en la terminal y ejecutaremos el siguiente código, que nos permitirá acceder con los datos de nuestro nuevo usuario:</p> <pre> su - noroot_user</pre> <p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 56.77%;" data-ratio="56.77" data-b-token="b-d523c699393" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img class="img-fluid media__element b-lazy b-filter" data-entity-uuid="c1bb62ba-cd14-4fb4-a5f2-513633de011c" data-responsive-image-style="" alt="docker - www.drupaladicto.org Formacion especializada en drupal y symfony - roles permisos y usuarios" decoding="async" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/cambiando_sesion_no_root.png?itok=odUPVSd-" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="620" height="352" typeof="foaf:Image" /></div></div> <h3>     Paso 3 - Otorgarle privilegios root a nuestro nuevo usuario:     </h3> <p>          Ahora, tenemos una nueva cuenta de usuario con privilegios de cuenta regulares. Sin embargo, es posible que a veces necesitemos realizar tareas administrativas. Para evitar tener que cerrar la sesión de nuestro usuario normal y volver a iniciarla como la cuenta root, podemos configurar lo que se conoce como "superusuario" o privilegios de root para nuestra cuenta normal. Esto permitirá a nuestro usuario normal ejecutar comandos con privilegios administrativos poniendo la palabra sudo antes de cada comando.</p> <p>          Como todavía tenemos abierta la pestaña de la terminal, donde habíamos iniciado sesión como root, vamos a ejecutar desde allí el siguiente código para otorgar los nuevos privilegios a nuestro usuario noroot_user:</p> <pre> usermod -aG sudo noroot_user</pre> <p>          Una vez otorgados los permisos de root, tendremos que cerrar la otra pestaña, donde está el usuario noroot_user, para poder comenzar a utilizarlos con los permisos recién adquiridos.</p> <p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 62.42%;" data-ratio="62.42" data-b-token="b-92d407d9889" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img class="img-fluid media__element b-lazy b-filter" data-entity-uuid="a009d2fd-8bfc-4dac-be69-035b235c9b21" data-responsive-image-style="" alt="docker - www.drupaladicto.org Formacion especializada en drupal y symfony - roles permisos y usuarios" decoding="async" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/permisos_root.png?itok=9WwjnClx" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="620" height="387" typeof="foaf:Image" /></div></div> <h3>     Paso 4 - Instalación del Servidor Apache</h3> <p>         Para instalar apache, vamos a necesitar dos comando:</p> <pre> sudo apt install apache2</pre> <pre> sudo service apache2 start</pre> <p>     Una vez instalado el servidor Apache, probemos que todo funciona, accediendo en el navegador a la url <strong>http://localhost. Deberíamos ver en pantalla la siguiente imagen:</strong></p> <p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 71.44%;" data-ratio="71.44" data-b-token="b-14cb96b2adb" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img class="img-fluid media__element b-lazy b-filter" data-entity-uuid="8e977e44-59ef-434b-a0a9-da50ab692052" data-responsive-image-style="" alt="apache - www.drupaladicto.org Formacion especializada en drupal y symfony - roles permisos y usuarios" decoding="async" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/apache.png?itok=vLy9aE6f" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="872" height="623" typeof="foaf:Image" /></div></div> <p>     Si todo es correcto, entonces podremos continuar y habilitaremos los módulos que vamos a necesitar, como el "Rewirte" o el "SSL"</p> <pre> sudo a2enmod rewrite</pre> <pre> sudo a2enmod ssl</pre> <p>     Y a continuación, para que se efectúen los cambios en el servidor, necesitaremos reiniciarlo usando el comando:</p> <pre> sudo service apache2 restart</pre> <p>     Llegado a este punto, te recomendaría ajustar la configuración de Apache para que los permisos coincidan con su nombre de usuario. En otras palabras, cuando hagas una lista de archivos, esta configuración de nombre de usuario que ingrese en Apache será la misma que la del propietario de los archivos en su sistema de archivos Linux. De esa forma, Apache tendrá permisos para modificar los archivos y carpetas de tu sitio. Si no lo haces, es posible que elementos como Grav y WP no funcionen correctamente o no funcionen en absoluto. Así que dirígete a este archivo y haz el siguiente cambio:</p> <pre> sudo nano /etc/apache2/envvars</pre> <pre> export APACHE_RUN_USER=your_user</pre> <pre> export APACHE_RUN_GROUP=your_user</pre> <p>     Y a continuación, una vez hayas editado el archivo envvars, para que se efectúen los cambios en el servidor, necesitaremos reiniciarlo usando el comando:</p> <pre> sudo service apache2 restart</pre> <p>     Ahora podemos comprobar si ambos módulos han sido activados correctamente, ejecutando el siguiente comando:</p> <pre> <code spellcheck="false">apache2ctl -M | egrep 'ssl|rewrite'</code></pre> <p>     Entonces en nuestra consola, si todo está correcto, deberíamos ver el siguiente mensaje:</p> <pre> <code spellcheck="false">#Enabled  rewrite_module (shared)  ssl_module (shared</code></pre> <h3>     Paso 5 - Instalación y configuración del Servidor de Base de datos MariaDB</h3> <p>          Lo primero que necesitaremos es instalar el servidor, ejecutando el siguiente comando:</p> <pre> sudo apt install mariadb-server mariadb-client</pre> <p><strong>     Importante: No se le pedirá que cree una contraseña, pero en una instalación local está bien. Y técnicamente no es inseguro de todos modos, ya que significa que solo aquellos con privilegios de sudo pueden acceder al servidor MySQL.</strong></p> <p>     Ahora necesitamos iniciar el servidor MySQL ejecutando el siguiente comando:</p> <pre> sudo service mysql start</pre> <h3>     Paso 6 - Instalación y configuración PHP</h3> <p>          En el caso de PHP, además de instalar la versión que vamos a utilizar, tendremos que realizar algunas modificaciones, como la activación de varias librerías, y otras modificaciones recomendadas para trabajar con Drupal, como el tiempo de ejecución o el máximo de tamaño de subida de archivos, pero vamos por partes, primero instalaremos php y activaremos algunas librerías necesarias:</p> <pre> sudo apt install php7.4-common php7.4-mysql php7.4-xml php7.4-xmlrpc php7.4-curl php7.4-gd php7.4-imagick php7.4-cli php7.4-dev php7.4-imap php7.4-mbstring php7.4-opcache php7.4-soap php7.4-zip php7.4-intl -y</pre> <p>          Es posible que también deba instalar módulos según los requisitos de su aplicación. Utilice el siguiente comando para buscar módulos PHP 7 disponibles en el repositorio de paquetes.</p> <pre> sudo apt-cache search php7*</pre> <p>          En nuestro caso, vamos a instalar los siguientes "módulos" de php:</p> <pre> sudo apt install php php-cli php-fpm php-json php-pdo php-mysql php-zip php-gd  php-mbstring php-curl php-xml php-pear php-bcmath</pre> <p>     Por últimos, vamos a realizar algunos de los cambios de configuración del PHP.ini que nos ayudarán y evitarán posibles errores una vez instalemos nuestro Drupal. Para ello, abriremos el archivo de configuración de php "php.ini" y realizaremos las modificaciones correspondientes:</p> <pre> sudo nano /etc/php/7.4/apache2/php.ini</pre> <ul><li>max_execution_time = 600</li> <li>post_max_size = 64M</li> <li>short_open_tag<br />    Default Value: On</li> <li>memory_limit = -1</li> <li>upload_max_filesize = 100M</li> </ul><p>     Una vez actualizados los cambios en el archivo de configuración de apache, volveremos a reiniciar nuestro servidor para que se guarden dichos cambios, para ello ejecutaremos el comando:</p> <pre> sudo service apache2 restart</pre> <p>     Ahora que PHP está instalado, para probar si está funcionando, cree un archivo de prueba llamado <strong>phpinfo.php</strong> en el directorio raíz predeterminado de Apache2…. (<strong>/ var / www / html /</strong>)</p> <pre> sudo nano /var/www/html/phpinfo.php</pre> <p>     Luego, escriba el contenido a continuación y guarde el archivo.</p> <pre> &lt;?php phpinfo( ); ?&gt;</pre> <p>     A continuación, abra su navegador y busque el nombre de host o la dirección IP del servidor seguido de <strong>phpinfo.php</strong></p> <p>http://localhost/phpinfo.php</p> <p>Debería ver la página de prueba predeterminada de PHP, como esta:</p> <p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 67.14%;" data-ratio="67.14" data-b-token="b-90318f7f083" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img class="img-fluid media__element b-lazy b-filter" data-entity-uuid="e3a4417c-2a21-4706-88a4-2717814ccc67" data-responsive-image-style="" alt="php ini - www.drupaladicto.org Formacion especializada en drupal y symfony - roles permisos y usuarios" decoding="async" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/phpini.png?itok=peg1iTNh" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="776" height="521" typeof="foaf:Image" /></div></div> <p>     Una vez comprobado que todo está correcto, tendremos que borrar este archivo ya que es información que implica riesgos de seguridad, para ello ejecutaremos el siguiente comando:</p> <pre> <code spellcheck="false">rm -f /var/www/html/info.php</code></pre> <h3>      Paso 7 - Instalación Interfaz Usuario para administrar MySql</h3> <p>          Aunque según los requerimientos de tu aplicación, puede que no te haga falta un entorno gráfico, para la administración de tus bases de datos y tablas, porque lo realizarás usando comandos de tu consola, te recomiendo instalar esta pequeña aplicación que te servirá de ayuda:</p> <pre> sudo apt install adminer</pre> <p>     Casi hemos terminado. Hay un problema para todos aquellos que cambiaron la configuración de usuario / grupo de Apache anterior. El administrador accede y escribe en su carpeta de sesiones de PHP, por lo que debe otorgarle a su usuario (el usuario que configuró en Apache) los permisos de la carpeta correspondiente a esa carpeta. Puedes realizar el cambio ejecutando el siguiente comando:</p> <pre> cd /var/lib/php</pre> <pre> sudo chown -R your_user:your_user sessions</pre> <p>     Ahora sí, lo último que nos faltará es activar Adminer, reiniciar Apache nuevamente, por supuesto, y luego verlo. Comience con estos dos comandos:</p> <pre> sudo a2enconf adminer.conf</pre> <pre> sudo service apache2 restart</pre> <p>     Para comprobar el Adminer funciona correctamente escribe en el navegador la url <strong>http://localhost/adminer/</strong></p> <p>     ¡Pero necesitamos un nombre de usuario para iniciar sesión ahora! Así que sigamos adelante y hagamos eso. <strong>Recuerde que todo esto es solo para desarrolladores locales</strong>, por lo que las preocupaciones de seguridad habituales relacionadas con la creación de un superusuario no se aplican realmente. Nunca hagas esto en un sitio en vivo. Siempre.</p> <p>     Así que inicie MySQL así:</p> <pre> sudo mysql</pre> <p>    Luego ingrese los siguientes comandos, Primero creamos el usuario que funcionará como root, luego le daremos los permisos para que pueda hacer cualquier tarea con las bases de datos, a continuación reseteamos la tabla de permisos y por último, saldremos de servidor de base de datos:</p> <pre> CREATE USER 'user_name'@'localhost' IDENTIFIED BY 'your_password';</pre> <pre> GRANT ALL PRIVILEGES ON * . * TO 'user_name'@'localhost';</pre> <pre> <code spellcheck="false">flush privileges;</code></pre> <pre> <code spellcheck="false">exit</code></pre> <p>     Ahora que haz creado un superusuario, ya podrás iniciar sesión en Adminer y comenzar a trabajar con tus bases de datos y tablas.</p> <blockquote> <p><strong>* Usuario con permisos específicos</strong></p> <p><strong>     </strong>Aunque tenemos un <strong>Super usuario</strong> con el cuál podremos realizar, todas las operaciones en nuestro servidor de base de datos, es <strong>muy recomendable</strong> limitar los accesos a la base de datos específica en cada proyecto. Por esta razón, a continuación vamos a crear un usuario y una base de datos específica para nuestro proyecto.</p> </blockquote> <p>     Primero nos vamos a loguear como Super usuario y una vez dentro, ejecutaremos cada una de las líneas siguientes, en las que primero crearemos la base de datos, luego el usuario con sus datos de acceso, a continuación le daremos todos los permisos, específicos para la tabla en concreto y por último el reseteo de la tabla de permisos:</p> <pre> sudo mysql;</pre> <pre> CREATE DATABASE drupaldb;</pre> <pre> CREATE USER drupaluser@localhost IDENTIFIED BY 'drupaluser@';</pre> <pre> GRANT ALL PRIVILEGES ON drupaldb.* to drupaluser@localhost identified by 'drupaluser@';</pre> <pre> FLUSH PRIVILEGES;</pre> <pre> EXIT</pre> <p>     Si queremos ver el listado de las bases de datos que tenemos creadas al momento, entraremos a MySql y luego ejecutamos el siguiente comando:</p> <pre> SHOW DATABASES;</pre> <p>     Para borrar una base de datos <strong>(Cuidado porque se perderá toda la información)</strong>, ejecutaremos:</p> <pre> DROP DATABASE mi_bd_para_borrar;</pre> <p>     Para ver el listado de usuarios creados, ejecutaremos el siguiente comando:</p> <pre> SELECT User FROM mysql.user;</pre> <p>     Para borrar un usuario específico:</p> <pre> DROP USER 'usuario'@'localhost';</pre> <h3>     Paso 8 - Configuración del Virtual Host y el SSL</h3> <p>          Para poder trabajar con certificados SSL, es necesario prestar atención en varios detalles previos, por eso, he preferido hacerlo en otro artículo con su video propio, que <a href="/actualidad/como-instalar-un-certificado-ssl-y-activar-https-en-drupal-9" target="_blank">podrás leer y ver haciendo clic aqui</a>  <a href="/actualidad/como-instalar-un-certificado-ssl-y-activar-https-en-drupal-9" target="_blank">Ver siguiente artículo</a></p> </div> </div> </div> </div> </div> </div> <div class="field field--name-field-categoria-post field--type-entity-reference field--label-above"> <div class="field__label">Categoría</div> <div class="field__items"> <div class="field__item"><a href="/categoria/servidor" hreflang="es">servidor</a></div> <div class="field__item"><a href="/categoria/lamp" hreflang="es">lamp</a></div> <div class="field__item"><a href="/categoria/apache" hreflang="es">apache</a></div> <div class="field__item"><a href="/categoria/php" hreflang="es">php</a></div> <div class="field__item"><a href="/categoria/mysql" hreflang="es">mysql</a></div> <div class="field__item"><a href="/categoria/server" hreflang="es">server</a></div> <div class="field__item"><a href="/categoria/local" hreflang="es">local</a></div> <div class="field__item"><a href="/categoria/desarrollo" hreflang="es">desarrollo</a></div> <div class="field__item"><a href="/categoria/development" hreflang="es">development</a></div> <div class="field__item"><a href="/categoria/entornos" hreflang="es">entornos</a></div> <div class="field__item"><a href="/categoria/linux" hreflang="es">linux</a></div> <div class="field__item"><a href="/categoria/console" hreflang="es">console</a></div> <div class="field__item"><a href="/categoria/consola" hreflang="es">consola</a></div> <div class="field__item"><a href="/categoria/ubuntu" hreflang="es">ubuntu</a></div> </div> </div> Wed, 08 Mar 2023 16:48:22 +0000 webmaster 261 at https://drupaladicto.com LAMP Server | Instalación con WSL2 en Windows 10 (2da Parte) https://drupaladicto.com/curso/entornos-locales/lamp-server-instalacion-con-wsl2-en-windows-10-2da-parte <span class="field field--name-title field--type-string field--label-hidden">LAMP Server | Instalación con WSL2 en Windows 10 (2da Parte)</span> <div class="field field--name-field-contenidos-cap-gratis field--type-entity-reference-revisions field--label-hidden field__items"> <div class="field__item"> <style>#video-only-929 .play-btn:hover::after { border-left: 15px solid #1fd7d9; transform: scale(20); border-left: 15px solid #fff; } #video-only-929 .play-btn::before { border: 5px solid #1fd7d9; } #video-only-929 .play-btn { background: radial-gradient(#1fd7d9 50%, rgba(66, 109, 202, 0.4) 52%); }</style> <div class="paragraph paragraph--type--video-only paragraph--view-mode--default" id="vol-929"> <section id="video-only-929" class="about area-padding video-block-wrapper"> <div class="col video-box"> <div class="portada"> <img src="/sites/default/files/styles/diapositiva_1200x650/public/2023-07/portada-gratuito-grande_2.jpg?itok=8dBQYXT7" class="img-fluid" alt=""> <div class="field field--name-vo-youtube-video field--type-entity-reference field--label-visually_hidden"> <div class="field__label visually-hidden">Video de Youtube</div> <div class="field__item"><article class="media media--type-remote-video media--view-mode-diapositiva-1200x650"> <div class="field field--name-field-media-oembed-video field--type-string field--label-visually_hidden"> <div class="field__label visually-hidden">URL de Video remoto</div> <div class="field__item"><div class="modal micromodal-slide" id="modal-media-649-0-field-media-oembed-video" aria-hidden="true"> <div class="modal__overlay" tabindex="-1" data-micromodal-close> <div class="modal__container" role="dialog" aria-modal="true" aria-labelledby="modal-media-649-0-field-media-oembed-video-content"> <a class="modal__btn" data-micromodal-close aria-label="Close this dialog window">X</a> <main class="modal__content" id="modal-media-649-0-field-media-oembed-video-content"> <div class="videoWrapper"><iframe src="/media/oembed?url=https%3A//youtu.be/8wPxDBKJg64&amp;max_width=0&amp;max_height=0&amp;hash=DmFcp3SLcQr0fGvqE0R3d93QNhe8tfBDJCqwr4hcPs4" frameborder="0" allowtransparency="" class="media-oembed-content" title="Time Value of Money"></iframe></div> </main> </div> </div> </div> <div><a class="myButton" data-micromodal-trigger="modal-media-649-0-field-media-oembed-video"><span class="btn play-btn">.</span></a></div> </div> </div> </article> </div> </div> </div> </div> </section> </div> </div> <div class="field__item"> <div class="paragraph paragraph--type--text-only paragraph--view-mode--default" id="txonly-1153" style="background-color: ;border: solid px;border-color: #096ba0;border-radius: 5px;padding: 10px;"> <div class="clearfix text-formatted field field--name-to-text field--type-text-long field--label-visually_hidden"> <div class="field__label visually-hidden">Texto</div> <div class="field__item"><h2><strong>Si no ves el video, puedes refrescar el navegador, presionando (Ctrl+Shift+R | Ctrl+F5 o Shift+F5), o abrirlo directamente desde el Canal de Youtube... <a href="https://youtu.be/8wPxDBKJg64" target="_blank">HAZ CLIC AQUI</a></strong></h2> <h3>Paso 5 Configuración del Virtual Host y el SSL</h3> <p>          Ahora que ya tenemos todos los requisitos previos a nuestra instalación de Drupal, que aprendimos en el artículo anterior <a href="https://www.drupaladicto.es/actualidad/como-instalar-lamp-usando-wsl2-en-windows-10-1era-parte">Cómo Instalar LAMP usando WSL2 en Windows 10 (1era Parte)</a>, ha llegado el momento de comenzar los preparativos, para que podamos instalar en nuestro servidor local, cualquier tipo de web, en nuestro caso, desarrollada con Drupal 9, funcionando con un certificado SSL.</p> <p>          Aunque en realidad, nuestro certificado será sólo para uso local, ya que no está autorizado, por ninguna de las entidades reales creadas con este propósito, nos permitirá realizar todo tipo de pruebas relacionadas con la seguridad como requisito, o por ejemplo, para el desarrollo de webs del tipo Progressive Web App (PWA), utilizando el módulo de Drupal, donde el certificado es obligatorio. </p> <p>         Existen varias herramientas y métodos con los que podríamos generar certificados SSL, una de las más conocidas es <a href="https://certbot.eff.org/">Certbot</a>, que se puede instalar en Linux y que ofrece la posibilidad de generar certificados autofirmados, para utilizar en entornos locales, que es el tipo que vamos a emplear en esta ocasión. Pero en lugar de usarlo, he preferido utlizar <strong>Openssl</strong>, que ya viene instalado dentro de la distribución de Ubuntu que hemos seleccionado para este artículo, así que empecemos:</p> <h2>Cómo Instalar un Certificado SSL y activar HTTPS en Drupal 9</h2> <h3>     1.- Ubicación de los certificados</h3> <p>          Como ya hemos dicho, el programa OpenSSL viene instalado en la distribución de Ubuntu 20.04, que es la que estamos utilizando. Para comprobarlo vamos a colocarnos en la carpeta donde se guardan los certificados de este programa y la utilizaremos como ubicación para los nuestros también. </p> <p>          Ejecutaremos los siguientes comandos, para ir hasta la carpeta y luego listar su contenido:</p> <pre> cd /etc/ssl</pre> <pre> sudo ls</pre> <p> </p> <p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 15.67%;" data-ratio="15.67" data-b-token="b-0e712f3d02c" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img alt="LAMP Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" title="LAMP Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" decoding="async" class="media__element b-lazy b-filter img-fluid" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/file-633003d5a3dc2.png?itok=4XJ893-k" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="351" height="55" typeof="foaf:Image" /></div></div> <h3>     2.- Generar los certificados</h3> <p>          Ahora que tenemos decidida la ubicación para nuestro certificado, y que ya hemos decidido el nombre que vamos a registrar, como dominio para nuestra web, lo siguiente que tendremos que hacer es ejecutar el siguiente comando sustituyendo <strong>drupal9.localhost</strong>, por el nombre o dominio con el que vamos a trabajar.</p> <pre> sudo openssl req -x509 -nodes -days 365 -newkey rsa:2048 -keyout /etc/ssl/drupal9.localhost.key -out /etc/ssl/drupal9.localhost.crt</pre> <p>         <strong>Explicación: </strong></p> <p>              Este código nos generará la clave privada <strong>drupal9.localhost</strong><strong>.key</strong>, que se utiliza para generar el certificado <strong>drupal9.localhost</strong><strong>.crt, </strong>con una duración de un año  <strong>-days 365</strong>, y guarda dichos certificados en este caso en la ubicación que le hemos especificado, o sea dentro de<strong> /etc/ssl/.</strong></p> <p><strong>        </strong> Una vez ejecutado el código, se mostrarán en pantalla varias preguntas que tendremos que rellenar e ir haciendo clic en aceptar, por cada respuesta que hayamos introducido:</p> <p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 36.46%;" data-ratio="36.46" data-b-token="b-0368a737f0c" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img alt="LAMP Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" title="LAMP Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" decoding="async" class="media__element b-lazy b-filter img-fluid" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/file-63300417d3eef.png?itok=dfegZSpy" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="650" height="237" typeof="foaf:Image" /></div></div> <h3>     3.- Permisos y descarga de Drupal</h3> <p>          Lo primero que tendremos que hacer en esta ocasión, es crear la carpeta donde se alojará nuestro Drupal 9, que instalaremos usando Composer, y que colocaremos dentro de la carpeta publica <strong>html</strong> del Apache, para ello ejecutaremos el siguiente comando:</p> <pre> sudo mkdir -p /var/www/html/<strong>drupal9.localhost</strong></pre> <p>     A continuación, daremos los permisos necesarios a nuestro usuario de apache para que podamos realizar la instalación sin compliacaiones:</p> <pre> cd /var/www/html/</pre> <pre> sudo chown -R www-data:www-data <strong>drupal9.localhost</strong>/</pre> <p>  Ya podremos empezar la descarga de nuestros archivos de instalación de Drupal 9 con Composer utilizando el siguiente comando y sustituyendo la última parte por el nombre de nuestra carpeta recién creada.</p> <pre> composer create-project drupal/recommended-project <strong>drupal9.localhost</strong></pre> <p>     De inmediato debería comenzar la descarga de los archivos de instalación desde el repositorio de Drupal.</p> <h3>     4.- Configuración del Virtual Host</h3> <p>          Una vez terminada la descarga de los archivos de Drupal, tendremos que configurar el acceso para poder comenzar con la instalación usando el navegador, para ello, crearemos el archivo de configuración correspondiente.</p> <pre> sudo nano /etc/apache2/sites-available/<strong>drupal9.localhost.conf</strong></pre> <p>     A continuación copiamos dentro el siguiente código:</p> <pre> &lt;VirtualHost *:80&gt;                 ServerName www.drupal9.localhost                 DocumentRoot /var/www/html/drupal9.localhost/web                 # Redirect http to https                 RedirectMatch 301 (.*) https://www.drupal9.localhost$1         &lt;/VirtualHost&gt;         &lt;VirtualHost _default_:443&gt;                 # Server Info                 ServerName www.drupal9.localhost                 ServerAlias drupal9.localhost                 ServerAdmin admin@drupal9.localhost                 # Web root                 DocumentRoot /var/www/html/drupal9.localhost/web                 # Log configuration                 ErrorLog ${APACHE_LOG_DIR}/drupal9.localhost-error.log                 CustomLog ${APACHE_LOG_DIR}/drupal9.localhost-access.log combined                 #   Enable/Disable SSL for this virtual host.                 SSLEngine on                 # Self signed SSL Certificate file                 SSLCertificateFile      /etc/ssl/drupal9.localhost.crt                 SSLCertificateKeyFile /etc/ssl/drupal9.localhost.key                 &lt;Directory "/var/www/html/drupal9.localhost/web"&gt;                         Options FollowSymLinks                         AllowOverride All                         Require all granted                 &lt;/Directory&gt;                 &lt;FilesMatch "\.(cgi|shtml|phtml|php)$"&gt;                                 SSLOptions +StdEnvVars                 &lt;/FilesMatch&gt;                 &lt;Directory /usr/lib/cgi-bin&gt;                                 SSLOptions +StdEnvVars                 &lt;/Directory&gt;                 BrowserMatch "MSIE [2-6]" \                                 nokeepalive ssl-unclean-shutdown \                                 downgrade-1.0 force-response-1.0                 # MSIE 7 and newer should be able to use keepalive                 BrowserMatch "MSIE [17-9]" ssl-unclean-shutdown         &lt;/VirtualHost&gt;</pre> <p>     Reemplace el nombre de dominio <strong>www.drupal9.localhost</strong> con el nombre de dominio de su sitio web Drupal.</p> <p>     Guarda el archivo y cierra.</p> <p>     Ahora comprueba si todo está correcto, ejecutando el siguiente comando:</p> <pre> apachectl configtest</pre> <p>    Si ves el mensaje <strong>"Syntax ok"</strong>, entonces la configuración de Apache es correcta.</p> <p>    Entonces podremos activar el Host Virtual de Drupal y reiniciar el servidor para que se ejecuten los cambios:</p> <pre> a2ensite drupal9.localhost</pre> <pre> sudo service apache2 restart</pre> </div> </div> </div> </div> </div> <span class="field field--name-uid field--type-entity-reference field--label-hidden"><span lang="" about="/luis-alberto-mejia" typeof="schema:Person" property="schema:name" datatype="">webmaster</span></span> <span class="field field--name-created field--type-created field--label-hidden">Mié, 08/03/2023 - 17:44</span> Wed, 08 Mar 2023 16:44:29 +0000 webmaster 260 at https://drupaladicto.com LAMP Server | Instalación con WSL2 en Windows 10 (1era Parte) https://drupaladicto.com/curso/entornos-locales/lamp-server-instalacion-con-wsl2-en-windows-10-1era-parte <span class="field field--name-title field--type-string field--label-hidden">LAMP Server | Instalación con WSL2 en Windows 10 (1era Parte)</span> <div class="field field--name-field-contenidos-cap-gratis field--type-entity-reference-revisions field--label-hidden field__items"> <div class="field__item"> <style>#video-only-928 .play-btn:hover::after { border-left: 15px solid #1fd7d9; transform: scale(20); border-left: 15px solid #fff; } #video-only-928 .play-btn::before { border: 5px solid #1fd7d9; } #video-only-928 .play-btn { background: radial-gradient(#1fd7d9 50%, rgba(66, 109, 202, 0.4) 52%); }</style> <div class="paragraph paragraph--type--video-only paragraph--view-mode--default" id="vol-928"> <section id="video-only-928" class="about area-padding video-block-wrapper"> <div class="col video-box"> <div class="portada"> <img src="/sites/default/files/styles/diapositiva_1200x650/public/2023-07/portada-gratuito-grande_2.jpg?itok=8dBQYXT7" class="img-fluid" alt=""> <div class="field field--name-vo-youtube-video field--type-entity-reference field--label-visually_hidden"> <div class="field__label visually-hidden">Video de Youtube</div> <div class="field__item"><article class="media media--type-remote-video media--view-mode-diapositiva-1200x650"> <div class="field field--name-field-media-oembed-video field--type-string field--label-visually_hidden"> <div class="field__label visually-hidden">URL de Video remoto</div> <div class="field__item"><div class="modal micromodal-slide" id="modal-media-648-0-field-media-oembed-video" aria-hidden="true"> <div class="modal__overlay" tabindex="-1" data-micromodal-close> <div class="modal__container" role="dialog" aria-modal="true" aria-labelledby="modal-media-648-0-field-media-oembed-video-content"> <a class="modal__btn" data-micromodal-close aria-label="Close this dialog window">X</a> <main class="modal__content" id="modal-media-648-0-field-media-oembed-video-content"> <div class="videoWrapper"><iframe src="/media/oembed?url=https%3A//youtu.be/jiyN-qhYPRU&amp;max_width=0&amp;max_height=0&amp;hash=AIPM3z7Qnt9uX_61Mdg-XWYw0-Trx622QL9gzPRGc5w" frameborder="0" allowtransparency="" class="media-oembed-content" title="Time Value of Money"></iframe></div> </main> </div> </div> </div> <div><a class="myButton" data-micromodal-trigger="modal-media-648-0-field-media-oembed-video"><span class="btn play-btn">.</span></a></div> </div> </div> </article> </div> </div> </div> </div> </section> </div> </div> <div class="field__item"> <div class="paragraph paragraph--type--text-only paragraph--view-mode--default" id="txonly-1152" style="background-color: ;border: solid px;border-color: #096ba0;border-radius: 5px;padding: 10px;"> <div class="clearfix text-formatted field field--name-to-text field--type-text-long field--label-visually_hidden"> <div class="field__label visually-hidden">Texto</div> <div class="field__item"><h2><strong>Si no ves el video, puedes refrescar el navegador, presionando (Ctrl+Shift+R | Ctrl+F5 o Shift+F5), o abrirlo directamente desde el Canal de Youtube... <a href="https://youtu.be/jiyN-qhYPRU" target="_blank">HAZ CLIC AQUI</a></strong></h2> <p>      Antes de trabajar en cualquier proyecto web, deberíamos contar con un entorno completo, que incluya todo lo necesario para que nuestra aplicación funcione correctamente, además de ofrecernos un lugar estable donde podamos realizar todo tipo de pruebas y procedimientos.</p> <p>     Aunque ya hemos explicado en otro artículo todo lo que necesitas saber sobre <a href="/actualidad/como-instalar-drupal-9-usando-docker-en-windows-10-home" hreflang="es">Cómo instalar Drupal 9 usando Docker en Windows 10 Home</a>, hoy te voy a contar cómo realizar la instalación completa de un servidor Linux que incluya, además, el Apache, Mysql y PHP, con la respectiva configuración del dominio para que puedas instalar Drupal en tu servidor local.</p> <h2>   Cómo Instalar LAMP usando WSL2 en Windows 10</h2> <h3>      Paso 1 Instalación y configuración de WSL2 en Windows</h3> <p>          Para no repetirme, puedes leer todo el proceso de instalación y configuración del WSL2 para Windows 10, en el artículo <a href="/actualidad/como-instalar-drupal-9-usando-docker-en-windows-10-home" target="_blank">Cómo instalar Drupal 9 usando Docker en Windows 10 Home (1era Parte)</a>, y una vez hayas realizado la instalación podrás continuar con el siguiente paso.</p> <p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 45.38%;" data-ratio="45.38" data-b-token="b-540b576ab28" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img alt="LAMP Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" title="LAMP Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" decoding="async" class="media__element b-lazy b-filter img-fluid" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/file-632fffc62757c.gif?itok=F1HU0UnK" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="650" height="295" typeof="foaf:Image" /></div></div> <p>          Además, antes de continuar, te recomiendo instalar la nueva terminal de Windows 10, para que puedas realizar operaciones simultáneas usando diferentes pestañas, te cuento cómo hacerlo en este artículo <a href="/actualidad/instalacion-y-configuracion-de-terminal-windows">Instalación y configuración de Terminal Windows</a></p> <p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div data-b-token="b-05759bedf3c" class="media media--blazy media--image media--ratio media--ratio--32 is-b-loading"><img alt="LAMP Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" title="LAMP Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" decoding="async" class="media__element b-lazy b-filter img-fluid" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/file-632ffff24f342.png?itok=qd8re8sj" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="600" height="400" typeof="foaf:Image" /></div></div> <p>     Ahora, antes de continuar, debe saber que puede omitir casi todos los pasos a continuación y simplemente hacer: <strong>sudo apt install lamp-server ^ phpmyadmin</strong>. Sin embargo, yo intenté hacerlo de esta forma y me dio varios errores, por lo que, en mi opinión recomiendo la opción "Larga", que además te dará control total sobre tu servidor y servicios instalados. </p> <h3><strong>      Paso 2 - crear un usuario No Root para la ejecución del código:</strong></h3> <p>          El usuario <strong>root</strong> es el usuario administrativo en un entorno Linux que tiene privilegios muy amplios. Debido a su inmenso poder, no se recomienda usarlo de forma regular. </p> <p>          El siguiente paso es configurar una cuenta de usuario alternativa, con un alcance de influencia reducido para el trabajo diario. Y podremos usar el la opción SUDO, cuando necesitemos permisos especiales sin tener que cambiar de usuario.</p> <p>          Con el siguiente código, voy a crear un usuario nuevo, que no será root, y que utilizaremos de aquí en adelante para el resto de la configuración.</p> <p>          Como por defecto en la instalación de ubuntu hemos creado el usuario root, ejecutaremos el siguiente comando con el prefijo sudo, y una vez complementada la información del nuevo usuario, que si no quieres rellenar la info puedes presionar ENTER en cada pregunta, como he hecho para este ejemplo.</p> <p>          Luego abriremos otra pestaña en la terminal de windows, si no la tienes instalada aprende cómo hacerlo en <a href="/actualidad/instalacion-y-configuracion-de-terminal-windows" target="_blank">Instalación y configuración de Terminal Windows</a>,  para no perder, de momento los accesos como root y luego continuaremos con el procedimiento:</p> <pre> adduser noroot_user</pre> <p> </p> <p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 56.77%;" data-ratio="56.77" data-b-token="b-f0102e5407e" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img alt="LAMP Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" title="LAMP Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" decoding="async" class="media__element b-lazy b-filter img-fluid" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/file-6330001540872.png?itok=AQHZl5bD" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="620" height="352" typeof="foaf:Image" /></div></div> <p>          Una vez creado el nuevo usuario, abriremos la nueva pestaña en la terminal y ejecutaremos el siguiente código, que nos permitirá acceder con los datos de nuestro nuevo usuario:</p> <pre> su - noroot_user</pre> <p> </p> <p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 56.77%;" data-ratio="56.77" data-b-token="b-906286d47c3" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img alt="LAMP Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" title="LAMP Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" decoding="async" class="media__element b-lazy b-filter img-fluid" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/file-6330003611a89.png?itok=zoWrFgyk" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="620" height="352" typeof="foaf:Image" /></div></div> <h3>     Paso 3 - Otorgarle privilegios root a nuestro nuevo usuario:     </h3> <p>          Ahora, tenemos una nueva cuenta de usuario con privilegios de cuenta regulares. Sin embargo, es posible que a veces necesitemos realizar tareas administrativas. Para evitar tener que cerrar la sesión de nuestro usuario normal y volver a iniciarla como la cuenta root, podemos configurar lo que se conoce como "superusuario" o privilegios de root para nuestra cuenta normal. Esto permitirá a nuestro usuario normal ejecutar comandos con privilegios administrativos poniendo la palabra sudo antes de cada comando.</p> <p>          Como todavía tenemos abierta la pestaña de la terminal, donde habíamos iniciado sesión como root, vamos a ejecutar desde allí el siguiente código para otorgar los nuevos privilegios a nuestro usuario noroot_user:</p> <pre> usermod -aG sudo noroot_user</pre> <p>          Una vez otorgados los permisos de root, tendremos que cerrar la otra pestaña, donde está el usuario noroot_user, para poder comenzar a utilizarlos con los permisos recién adquiridos.</p> <p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 62.42%;" data-ratio="62.42" data-b-token="b-954e411f891" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img alt="LAMP Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" title="LAMP Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" decoding="async" class="media__element b-lazy b-filter img-fluid" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/file-633000589ed91.png?itok=PPASKGfS" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="620" height="387" typeof="foaf:Image" /></div></div> <h3>     Paso 4 - Instalación del Servidor Apache</h3> <p>         Para instalar apache, vamos a necesitar dos comando:</p> <pre> sudo apt install apache2</pre> <pre> sudo service apache2 start</pre> <p>     Una vez instalado el servidor Apache, probemos que todo funciona, accediendo en el navegador a la url <strong>http://localhost. Deberíamos ver en pantalla la siguiente imagen:</strong></p> <p> </p> <p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 71.5%;" data-ratio="71.5" data-b-token="b-d72c4fe86d6" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img alt="LAMP Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" title="LAMP Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" decoding="async" class="media__element b-lazy b-filter img-fluid" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/file-6330007a7ca98.png?itok=H7iSZnBY" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="600" height="429" typeof="foaf:Image" /></div></div> <p>     Si todo es correcto, entonces podremos continuar y habilitaremos los módulos que vamos a necesitar, como el "Rewirte" o el "SSL"</p> <pre> sudo a2enmod rewrite</pre> <pre> sudo a2enmod ssl</pre> <p>     Y a continuación, para que se efectúen los cambios en el servidor, necesitaremos reiniciarlo usando el comando:</p> <pre> sudo service apache2 restart</pre> <p>     Llegado a este punto, te recomendaría ajustar la configuración de Apache para que los permisos coincidan con su nombre de usuario. En otras palabras, cuando hagas una lista de archivos, esta configuración de nombre de usuario que ingrese en Apache será la misma que la del propietario de los archivos en su sistema de archivos Linux. De esa forma, Apache tendrá permisos para modificar los archivos y carpetas de tu sitio. Si no lo haces, es posible que elementos como Grav y WP no funcionen correctamente o no funcionen en absoluto. Así que dirígete a este archivo y haz el siguiente cambio:</p> <pre> sudo nano /etc/apache2/envvars</pre> <pre> export APACHE_RUN_USER=your_user</pre> <pre> export APACHE_RUN_GROUP=your_user</pre> <p>     Y a continuación, una vez hayas editado el archivo envvars, para que se efectúen los cambios en el servidor, necesitaremos reiniciarlo usando el comando:</p> <pre> sudo service apache2 restart</pre> <p>     Ahora podemos comprobar si ambos módulos han sido activados correctamente, ejecutando el siguiente comando:</p> <pre> apache2ctl -M | egrep 'ssl|rewrite'</pre> <p>     Entonces en nuestra consola, si todo está correcto, deberíamos ver el siguiente mensaje:</p> <pre> #Enabled  rewrite_module (shared)  ssl_module (shared</pre> <h3>     Paso 5 - Instalación y configuración del Servidor de Base de datos MariaDB</h3> <p>          Lo primero que necesitaremos es instalar el servidor, ejecutando el siguiente comando:</p> <pre> sudo apt install mariadb-server mariadb-client</pre> <p><strong>     Importante: No se le pedirá que cree una contraseña, pero en una instalación local está bien. Y técnicamente no es inseguro de todos modos, ya que significa que solo aquellos con privilegios de sudo pueden acceder al servidor MySQL.</strong></p> <p>     Ahora necesitamos iniciar el servidor MySQL ejecutando el siguiente comando:</p> <pre> sudo service mysql start</pre> <h3>     Paso 6 - Instalación y configuración PHP</h3> <p>          En el caso de PHP, además de instalar la versión que vamos a utilizar, tendremos que realizar algunas modificaciones, como la activación de varias librerías, y otras modificaciones recomendadas para trabajar con Drupal, como el tiempo de ejecución o el máximo de tamaño de subida de archivos, pero vamos por partes, primero instalaremos php y activaremos algunas librerías necesarias:</p> <pre> sudo apt install php7.4-common php7.4-mysql php7.4-xml php7.4-xmlrpc php7.4-curl php7.4-gd php7.4-imagick php7.4-cli php7.4-dev php7.4-imap php7.4-mbstring php7.4-opcache php7.4-soap php7.4-zip php7.4-intl -y</pre> <p>          Es posible que también deba instalar módulos según los requisitos de su aplicación. Utilice el siguiente comando para buscar módulos PHP 7 disponibles en el repositorio de paquetes.</p> <pre> sudo apt-cache search php7*</pre> <p>          En nuestro caso, vamos a instalar los siguientes "módulos" de php:</p> <pre> sudo apt install php php-cli php-fpm php-json php-pdo php-mysql php-zip php-gd  php-mbstring php-curl php-xml php-pear php-bcmath</pre> <p>     Por últimos, vamos a realizar algunos de los cambios de configuración del PHP.ini que nos ayudarán y evitarán posibles errores una vez instalemos nuestro Drupal. Para ello, abriremos el archivo de configuración de php "php.ini" y realizaremos las modificaciones correspondientes:</p> <pre> sudo nano /etc/php/7.4/apache2/php.ini</pre> <ul><li>max_execution_time = 600</li> <li>post_max_size = 64M</li> <li>short_open_tag<br />    Default Value: On</li> <li>memory_limit = -1</li> <li>upload_max_filesize = 100M</li> </ul><p>     Una vez actualizados los cambios en el archivo de configuración de apache, volveremos a reiniciar nuestro servidor para que se guarden dichos cambios, para ello ejecutaremos el comando:</p> <pre> sudo service apache2 restart</pre> <p>     Ahora que PHP está instalado, para probar si está funcionando, cree un archivo de prueba llamado <strong>phpinfo.php</strong> en el directorio raíz predeterminado de Apache2…. (<strong>/ var / www / html /</strong>)</p> <pre> sudo nano /var/www/html/phpinfo.php</pre> <p>     Luego, escriba el contenido a continuación y guarde el archivo.</p> <pre> &lt;?php phpinfo( ); ?&gt;</pre> <p>     A continuación, abra su navegador y busque el nombre de host o la dirección IP del servidor seguido de <strong>phpinfo.php</strong></p> <p>http://localhost/phpinfo.php</p> <p>Debería ver la página de prueba predeterminada de PHP, como esta:</p> <p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 67.08%;" data-ratio="67.08" data-b-token="b-7933f8dc4b4" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img alt="LAMP Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" title="LAMP Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" decoding="async" class="media__element b-lazy b-filter img-fluid" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/file-6330013689a35.png?itok=-4iK_ZnT" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="650" height="436" typeof="foaf:Image" /></div></div> <p>     Una vez comprobado que todo está correcto, tendremos que borrar este archivo ya que es información que implica riesgos de seguridad, para ello ejecutaremos el siguiente comando:</p> <pre> rm -f /var/www/html/info.php</pre> <h3>      Paso 7 - Instalación Interfaz Usuario para administrar MySql</h3> <p>          Aunque según los requerimientos de tu aplicación, puede que no te haga falta un entorno gráfico, para la administración de tus bases de datos y tablas, porque lo realizarás usando comandos de tu consola, te recomiendo instalar esta pequeña aplicación que te servirá de ayuda:</p> <pre> sudo apt install adminer</pre> <p>     Casi hemos terminado. Hay un problema para todos aquellos que cambiaron la configuración de usuario / grupo de Apache anterior. El administrador accede y escribe en su carpeta de sesiones de PHP, por lo que debe otorgarle a su usuario (el usuario que configuró en Apache) los permisos de la carpeta correspondiente a esa carpeta. Puedes realizar el cambio ejecutando el siguiente comando:</p> <pre> cd /var/lib/php</pre> <pre> sudo chown -R your_user:your_user sessions</pre> <p>     Ahora sí, lo último que nos faltará es activar Adminer, reiniciar Apache nuevamente, por supuesto, y luego verlo. Comience con estos dos comandos:</p> <pre> sudo a2enconf adminer.conf</pre> <pre> sudo service apache2 restart</pre> <p>     Para comprobar el Adminer funciona correctamente escribe en el navegador la url <strong>http://localhost/adminer/</strong></p> <p>     ¡Pero necesitamos un nombre de usuario para iniciar sesión ahora! Así que sigamos adelante y hagamos eso. <strong>Recuerde que todo esto es solo para desarrolladores locales</strong>, por lo que las preocupaciones de seguridad habituales relacionadas con la creación de un superusuario no se aplican realmente. Nunca hagas esto en un sitio en vivo. Siempre.</p> <p>     Así que inicie MySQL así:</p> <pre> sudo mysql</pre> <p>    Luego ingrese los siguientes comandos, Primero creamos el usuario que funcionará como root, luego le daremos los permisos para que pueda hacer cualquier tarea con las bases de datos, a continuación reseteamos la tabla de permisos y por último, saldremos de servidor de base de datos:</p> <pre> CREATE USER 'user_name'@'localhost' IDENTIFIED BY 'your_password';</pre> <pre> GRANT ALL PRIVILEGES ON * . * TO 'user_name'@'localhost';</pre> <pre> flush privileges;</pre> <pre> exit</pre> <p>     Ahora que haz creado un superusuario, ya podrás iniciar sesión en Adminer y comenzar a trabajar con tus bases de datos y tablas.</p> <p><strong>* Usuario con permisos específicos</strong></p> <p><strong>     </strong>Aunque tenemos un <strong>Super usuario</strong> con el cuál podremos realizar, todas las operaciones en nuestro servidor de base de datos, es <strong>muy recomendable</strong> limitar los accesos a la base de datos específica en cada proyecto. Por esta razón, a continuación vamos a crear un usuario y una base de datos específica para nuestro proyecto.</p> <p>     Primero nos vamos a loguear como Super usuario y una vez dentro, ejecutaremos cada una de las líneas siguientes, en las que primero crearemos la base de datos, luego el usuario con sus datos de acceso, a continuación le daremos todos los permisos, específicos para la tabla en concreto y por último el reseteo de la tabla de permisos:</p> <pre> sudo mysql;</pre> <pre> CREATE DATABASE drupaldb;</pre> <pre> CREATE USER drupaluser@localhost IDENTIFIED BY 'drupaluser@';</pre> <pre> GRANT ALL PRIVILEGES ON drupaldb.* to drupaluser@localhost identified by 'drupaluser@';</pre> <pre> FLUSH PRIVILEGES;</pre> <pre> EXIT</pre> <p>     Si queremos ver el listado de las bases de datos que tenemos creadas al momento, entraremos a MySql y luego ejecutamos el siguiente comando:</p> <pre> SHOW DATABASES;</pre> <p>     Para borrar una base de datos <strong>(Cuidado porque se perderá toda la información)</strong>, ejecutaremos:</p> <pre> DROP DATABASE mi_bd_para_borrar;</pre> <p>     Para ver el listado de usuarios creados, ejecutaremos el siguiente comando:</p> <pre> SELECT User FROM mysql.user;</pre> <p>     Para borrar un usuario específico:</p> <pre> DROP USER 'usuario'@'localhost';</pre> <h3>     Paso 8 - Configuración del Virtual Host y el SSL</h3> <p>          Para poder trabajar con certificados SSL, es necesario prestar atención en varios detalles previos, por eso, he preferido hacerlo en otro artículo con su video propio, que <a href="/actualidad/como-instalar-un-certificado-ssl-y-activar-https-en-drupal-9" target="_blank">podrás leer y ver haciendo clic aqui</a>  <a href="/actualidad/como-instalar-un-certificado-ssl-y-activar-https-en-drupal-9" target="_blank">Ver siguiente artículo</a></p> </div> </div> </div> </div> </div> <span class="field field--name-uid field--type-entity-reference field--label-hidden"><span lang="" about="/luis-alberto-mejia" typeof="schema:Person" property="schema:name" datatype="">webmaster</span></span> <span class="field field--name-created field--type-created field--label-hidden">Mié, 08/03/2023 - 17:38</span> Wed, 08 Mar 2023 16:38:11 +0000 webmaster 259 at https://drupaladicto.com Backup and Migrate https://drupaladicto.com/curso/backup-and-migrate <span class="field field--name-title field--type-string field--label-hidden">Backup and Migrate</span> <span class="field field--name-uid field--type-entity-reference field--label-hidden"><span lang="" about="/luis-alberto-mejia" typeof="schema:Person" property="schema:name" datatype="">webmaster</span></span> <span class="field field--name-created field--type-created field--label-hidden">Lun, 06/03/2023 - 23:18</span> <div class="field field--name-field-contenidos-post field--type-entity-reference-revisions field--label-visually_hidden"> <div class="field__label visually-hidden">Contenidos</div> <div class="field__items"> <div class="field__item"> <style>#video-only-1041 .play-btn:hover::after { border-left: 15px solid #1fd7d9; transform: scale(20); border-left: 15px solid #fff; } #video-only-1041 .play-btn::before { border: 5px solid #1fd7d9; } #video-only-1041 .play-btn { background: radial-gradient(#1fd7d9 50%, rgba(66, 109, 202, 0.4) 52%); }</style> <div class="paragraph paragraph--type--video-only paragraph--view-mode--default" id="vol-1041"> <section id="video-only-1041" class="about area-padding video-block-wrapper"> <div class="col video-box"> <div class="portada"> <img src="/sites/default/files/styles/diapositiva_1200x650/public/2023-07/custom-module.jpg?itok=5PSIHo9t" class="img-fluid" alt=""> <div class="field field--name-vo-youtube-video field--type-entity-reference field--label-visually_hidden"> <div class="field__label visually-hidden">Video de Youtube</div> <div class="field__item"><article class="media media--type-remote-video media--view-mode-diapositiva-1200x650"> <div class="field field--name-field-media-oembed-video field--type-string field--label-visually_hidden"> <div class="field__label visually-hidden">URL de Video remoto</div> <div class="field__item"><div class="modal micromodal-slide" id="modal-media-738-0-field-media-oembed-video" aria-hidden="true"> <div class="modal__overlay" tabindex="-1" data-micromodal-close> <div class="modal__container" role="dialog" aria-modal="true" aria-labelledby="modal-media-738-0-field-media-oembed-video-content"> <a class="modal__btn" data-micromodal-close aria-label="Close this dialog window">X</a> <main class="modal__content" id="modal-media-738-0-field-media-oembed-video-content"> <div class="videoWrapper"><iframe src="/media/oembed?url=https%3A//youtu.be/95fsIISibu4&amp;max_width=0&amp;max_height=0&amp;hash=4F1D-zZuNDOyswsj0-hFzjJrK__QoEupCFLsS_Y453c" frameborder="0" allowtransparency="" class="media-oembed-content" title="Time Value of Money"></iframe></div> </main> </div> </div> </div> <div><a class="myButton" data-micromodal-trigger="modal-media-738-0-field-media-oembed-video"><span class="btn play-btn">.</span></a></div> </div> </div> </article> </div> </div> </div> </div> </section> </div> </div> <div class="field__item"> <div class="paragraph paragraph--type--text-only paragraph--view-mode--default" id="txonly-1042" style="background-color: ;border: solid 2px;border-color: #096ba0;border-radius: 5px;padding: 10px;"> <div class="clearfix text-formatted field field--name-to-text field--type-text-long field--label-visually_hidden"> <div class="field__label visually-hidden">Texto</div> <div class="field__item"><p>  Imagina que estás trabajando en un nuevo proyecto con Drupal 8 o 9 en tu ordenador, estás modificando contenidos, estructuras, taxonomías y de pronto ocurre un error que te deja sin acceso a la última versión estable de tu proyecto.</p> <p>Por esta razón es muy recomendable que el segundo módulo que instales en cualquier Drupal sea <strong>Backup and Migrate, </strong>por que podrás realizar copias de seguridad antes de instalar otros módulos o aplicar cambios importantes. Además tendrás la opción de descargar el archivo comprimido, si quieres hacer un traspaso de tu instalación hacia otro entorno para aplicar dichos cambios inmediatamente o podrás programarlas para que se hagan automáticamente en tu servidor de producción.</p> <h3>Cómo instalar y configurar el módulo:</h3> <p><strong>Paso 1 Descargar el módulo:</strong></p> <p>     Lo primero que tendrás que hacer es descargarlo, para ello, a partir de Drupal 8 se recomienda que utilices el gestor de paquetes <a href="https://getcomposer.org/" target="_blank">Composer</a>, ya que te facilitará tanto la instalación como futuras actualizaciones del tus proyectos. No obstante también podrías descargarlo desde la <a href="https://www.drupal.org/project/backup_migrate" target="_blank">Página oficial del módulo</a> y una vez descargado, tendrás que colocarlo en la carpeta "modules" o "modules/contrib", dependiendo de tu instalación.</p> <p><strong>Paso 2 Configuración del settings:</strong></p> <p>     Configuración de los archivos privados dentro de "Settings.php", este paso es muy importante, porque el módulo Backup and Migrate utiliza por defecto, los archivos privados de Drupal, ya que las copias de seguridad no deberían estar disponibles para nadie más que los administradores del sitio. </p> <p>     Si abres tu archivo "settings.php" con tu editor de texto o IDE favorito y buscas la palabra "private", encontrarás varias líneas de código que te explican cómo funciona, además de la línea específica, que deberás descomentar, borrando la almohadilla "#" para luego añadir la ubicación que tendrá tu archivo private.</p> <p>     Puedes utilizar por ejemplo: "<strong>$settings['file_private_path'] = '../private</strong>'; esto significa que tu carpeta "private" estará colocada a nivel de tu directorio Raiz y que dentro el módulo Backup and Migrate creará dentro su propia carpeta con los accesos y permisos requeridos para que funcione correctamente.</p> <p>     </p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 43.23%;" data-ratio="43.23" data-b-token="b-0ec778868c0" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img data-entity-uuid="70584fcb-1a11-422d-bd86-11ae7bea51d9" alt="Backup and Migrate Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" decoding="async" class="media__element b-lazy b-filter img-fluid" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/private_settings.png?itok=Xw5DOuqY" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="650" height="281" typeof="foaf:Image" /></div></div> <p><strong>Paso 3 Activación del módulo</strong> :</p> <p>     Para activar el módulo Backup and migrate, al igual que todos los demás módulos contribuidos de Drupal, tendrás la posibilidad de hacerlo, mediante el uso de la herramienta Drush, con el comando "drush en backup_migrate -y", que sirve para activar cualquier módulos y todas sus dependencias, o desde la interfaz de drupal.   </p> <p> </p> <p><strong>Paso 4 Comprobación:</strong></p> <p>     Ahora que ya tenemos activado el módulo y que hemos configurado correctamente el archivo "settings.php" y la carpeta para los archivos privados y las copias del módulo, nos toca asegurarnos de que todo funciona según el plan.</p> <p>     Para ello puedes acceder a la pantalla de configuraciones del módulo, desde el menú superior y luego crear tu primera copia de seguridad, asegurándote de que la copia se guardará en los archivos privados y después haciendo clic en el botón de "hacer copia de seguridad ahora", una vez realizada la copia:</p> <pre>  <strong>https://miproyecto_drupal/admin/config/development/backup_migrate</strong></pre> <p> </p> <p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 52.96%;" data-ratio="52.96" data-b-token="b-6f43dce3f03" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img data-entity-uuid="82eea3b2-1f7b-432e-8448-a856e568a806" alt="Backup and Migrate Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" decoding="async" class="media__element b-lazy b-filter img-fluid" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/accer_al_bk_migrate.jpg?itok=d50lV-3M" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="1097" height="581" typeof="foaf:Image" /></div></div> <p> </p> <p>     Si todo está correcto verás un mensaje de confirmación y luego podrás buscar la copia guardada, en la pestaña "copias de seguridad guardadas", o si lo prefieres, también podrás descargar el archivo comprimido, por si quieres trasladar tu proyecto a otro entorno.</p> <p> </p> <p></p><div class="media-wrapper media-wrapper--blazy media-wrapper--image"> <div style="padding-bottom: 96.72%;" data-ratio="96.72" data-b-token="b-f5267692d68" class="media media--blazy media--image media--ratio media--ratio--fluid is-b-loading"><img data-entity-uuid="4d946552-4218-4dfd-a1e2-38eb436dedaa" alt="Backup and Migrate Drupal | www.drupaladicto.com - Consultor especializado en drupal y symfony" decoding="async" class="media__element b-lazy b-filter img-fluid" loading="lazy" data-src="/sites/default/files/styles/max_1300x1300/public/inline-images/copia_completada.png?itok=f6i_cSjr" src="data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%201%201'%2F%3E" width="549" height="531" typeof="foaf:Image" /></div></div> </div> </div> </div> </div> </div> </div> <div class="field field--name-field-categoria-top field--type-entity-reference field--label-above"> <div class="field__label">Categoria</div> <div class="field__items"> <div class="field__item"><a href="/categoria/administracion" hreflang="es">administración</a></div> <div class="field__item"><a href="/categoria/backend" hreflang="es">backend</a></div> <div class="field__item"><a href="/categoria/backup" hreflang="es">backup</a></div> <div class="field__item"><a href="/categoria/bases-de-datos" hreflang="es">bases de datos</a></div> <div class="field__item"><a href="/categoria/configuraciones" hreflang="es">configuraciones</a></div> <div class="field__item"><a href="/categoria/copia-seguridad" hreflang="es">copia seguridad</a></div> <div class="field__item"><a href="/categoria/drupal-7" hreflang="es">drupal 7</a></div> <div class="field__item"><a href="/categoria/drupal-8" hreflang="es">drupal 8</a></div> <div class="field__item"><a href="/categoria/drupal-9" hreflang="es">drupal 9</a></div> <div class="field__item"><a href="/categoria/migracion" hreflang="es">migración</a></div> <div class="field__item"><a href="/categoria/modulo" hreflang="es">modulo</a></div> <div class="field__item"><a href="/categoria/module" hreflang="es">module</a></div> <div class="field__item"><a href="/categoria/mysql" hreflang="es">mysql</a></div> </div> </div> Mon, 06 Mar 2023 22:18:07 +0000 webmaster 212 at https://drupaladicto.com