Guías sobre temas de bases de datos y programación
Ingresa 👉 aquí para ir a la página de descarga, ya esta seleccionado el archivo, solo damos clic en donde está señalado en la siguiente ilustración y comenzará la descarga.
Comienza la decarga
Extraemos el contenido en el directorio deseado
El archivo de opciones es la configuración que se utilizará para iniciar el servidor de base de datos MySQL.
Si es necesario especificarle opciones al servidor durante su inicio, esto también puede hacerse desde la línea de comandos pero es conveniente colocarlas en un archivo.
Esto es especialmente necesario en las siguiente circuntancias:
📁 C:\Program Files\MySQL\MySQL Server 8.x
📁 C:\Program Files\MySQL\MySQL Server 8.x\data
Los parámetros declarados dentro del archivo de opciones son leidos como la configuración para iniciar el servidor de base de datos MySQL.
El archivo dentro tiene una sección o directiva exclusiva para el servidor [mysqld]
donde se puede definir la siguiente información:
basedir
: el directorio base de instalación.datadir
: la ubicación del directorio de datos.Un archivo de opciones puede crearse y modificarse con cualquier editor de texto, como el bloc de notas lo importante es guardar el archivo como my.ini en el directorio raíz Ej: C:\MySQL8.
La modificación de este archivo conlleva el actualizar las configuraciones del servidor al iniciarse, por lo que cada vez que realicemos cambios en este archivo debemos detener el servidor e iniciarlo nuevamente una vez salvado los cambios.
En la raíz de donde se descomprimieron los archivos, creamos un nuevo archivo de opciones
A continuación están las opciones más recomendadas para definirlas en base a sus necesidades:
[client]
port=3306
[mysqld]
basedir=C:/MySQL8
datadir=C:/data
port=3306
key_buffer_size=16M
max_allowed_packet=8M
[mysqldump]
quick
Aunque MySQL ya viene con valores predeterminado en la configuración inicial, nos bastaría con solo indicar los parámetros basedir
y datadir
y siempre puede ver más opciones en su sitio web oficial.
Los nombres de las rutas de acceso de Windows se especifican en los archivos de opciones mediante barras diagonales (hacia adelante) en lugar de barras diagonales inversas. Si usa barras invertidas, duplíquelas Ej:
[mysqld]
basedir=C:\\MySQL8
datadir=C:\\data
nota: Si la carpeta que hemos definidos para los datos no existe, la creará por nosotros, pero si debe existir el destino de ruta que hemos indicado.
Como hemos apreciado el paquete ZIP no incluye un directorio data. Para inicializar una instalación de MySQL, en caso de que no hayamos creando el archivo de opciones, se creara un directorio data dentro del directorio de instalación y dentro de ese directorio se crearan las bases de datos del sistema llenando las tablas del sistema MySQL.
Usando el siguiente comando para inicializar el servidor:
mysqld --initialize o --initialize-insecure.
Este comando hace lo siguiente:
Implementación segura por defecto
--random-password-file
está disponible para controlar dónde se escribe la contraseña aleatoria.
Esto puede tardar unos segundos o minutos
Al permitir el acceso del firewall del sistema, nos debe mostrar el siguiente mensaje al ejecutarse.
La opción --console
es para ver el log en la línea de comandos y nos debe indicar que se encuentra listo para recibir conexiones entrantes.
En nuestro caso especificamos el destino para las bases de datos del sistema y el resto en 📁 C:\mysql8_data
si no la encuentra la crea y almacena el contenido. Si desea utilizar un directorio de datos en una ubicación diferente, debe copiar todo el contenido del directorio data en la nueva ubicación. Por ejemplo, si desea utilizarlo C:\mydata
como directorio de datos, se puede hacer de dos formas:
Mueva todo el directorio data y todo su contenido desde la ubicación predeterminada. Por ejemplo 📁 C:\mysql_data
a 📁 C:\mydata
y luego debes detener el servidor, realizar los cambios en el archivo de opciones y se vuelve a iniciar el servidor.
Utilizar la opción --datadir
en la línea de comandos para especificar la nueva ubicación del directorio de datos cada vez que iniciemos el servidor. Ej:
mysqld --datadir 'path\your\data'
Independiente de la configuración que hemos dado para conectarnos al servidor, primero que nada debemos inicializarlo, y luego conectarnos como clientes, dentro de la carpeta data se encuentra un archivo llamado con el nombre de tu equipo y la extensión .err
abrimos ese archivo con el bloc de nota y buscamos el password generado para el usuario root de manera temporal:
Abrimos el archivo con extensión .err
Copiamos el password
Ahora la primera tarea antes de comenzar a manipular bases de datos, será cambiar el password de nuestro usuario root. De hecho si intentamos ejecutar un comando sql nos va a requerir esta acción ya que el password generado con la inicialización tiene el estado de caducado.
La declaración ALTER_USER
modifica las cuentas de MySQL. Permite modificar las propiedades de autenticación, SSL/TLS, límite de recursos y administración de contraseñas para las cuentas existentes.
Para cada cuenta afectada, ALTER USER
modifica la fila correspondiente en la tabla mysql.user
del sistema para reflejar las propiedades especificadas en el extracto. Las propiedades no especificadas conservan sus valores actuales.
ALTER USER USER() IDENTIFIED BY 'proPassword123';
Esta sintaxis permite cambiar su propia contraseña sin nombrar literalmente su cuenta. A continuación hemos dado un password al usuario root con el que nos conectamos la contraseña generada temporalmente por el servidor al momento de su instalación.
Ahora recargamos los privilegios con:
FLUSH PRIVILEGES;
Ahora ya podemos conectarnos con la nueva contraseña que hemos asignado, podemos consultar en la tabla de usuario el complemento de autenticación con el siguiente comando:
SELECT user, plugin FROM mysql.user;
Adicionalmente, podemos establecer esta ruta de donde lanzamos el servidor como variable de entorno para que nos resulte más comodo lanzar el servidor desde cualquier ubicación. Con el siguiente comando podemos establecer la ruta de instalación de MySQL a la variable path del usuario:
En CMD:
SETX PATH "%path%;"C:\MySQL8\bin\
Para invocar a mysql en CMD o PowerShell:
mysql -u root -p
Cerramos la ventana de comandos y abrimos una nueva.
Nos posicionamos dentro del directorio de instalación e ingresamos a la carpeta bin y ejecutamos los siguientes comandos. Para llevar a cabo estos pasos es necesario abrir la sesión de CMD con privilegios de administrador.
El siguiente comando es para asegurarte de no tener ninguna instancia del servidor corriendo actualmente:
mysqladmin -u root shutdown
El siguiente comando registra MySQL como servicio:
mysqld --install "MySQL8"
Se registra con el nombre pasado como argumento. De lo contrario solo con el nombre MySQL por defecto.
Ahora ya podemos iniciar el servicio o detenerlo desde la línea de comandos, pero para llevar a cabo el proceso tenemos que abrir una nueva línea de comando como administrador.
Iniciar el servicio con el comando net
net start MySQL
Detener el servicio con el comando:
net stop MySQL
Eliminar el servicio
sc delete "MySQL"