Reputation: 3168
When I am invoking the file mysql_secure_installation
I get an error like
[mysqk123@InstallZeMo bin]$ ./mysql_secure_installation
NOTE: RUNNING ALL PARTS OF THIS SCRIPT IS RECOMMENDED FOR ALL MySQL
SERVERS IN PRODUCTION USE! PLEASE READ EACH STEP CAREFULLY!
In order to log into MySQL to secure it, we'll need the current
password for the root user. If you've just installed MySQL, and
you haven't set the root password yet, the password will be blank,
so you should just press enter here.
Enter current password for root (enter for none):
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)
Enter current password for root (enter for none):
but the given sock file in my.cnf file is /home/mysqk123/tmp/mysql.sock and I am using redhat linux 5.3 and mysql 5.1.47
I know that the tasks performed by mysql_secure_installation script can be performed manually but here I have to run the script [ not allowed to do the task manually ]
Upvotes: 22
Views: 49787
Reputation: 329
mysql_secure_instllation
creates it's own (hidden and temporary) my.cnf
file in the current working directory. With a vanilla install this shouldn't cause issues, but if you have configured your SQL server to put the socket in a non-standard location, this will cause issues.
To work around this, ensure you have properly configured your /etc/my.cnf
file with the appropriate socket=/dir/to/mysql/socket.sock
option. With this configured, tell mysql_secure_installation
to use this file with the --defaults-file
argument as such:
mysql_secure_installation --defaults-file=/etc/my.cnf
Upvotes: 2
Reputation: 344
DO THIS if you are using mariadb
Before TO RUN : mysql_secure_installation
Step 1: sudo systemctl stop mariadb
Step 2: sudo systemctl start mariadb
Step 3: mysql_secure_installation
It will ask root password and you can simply press Enter and set your new root password.
Upvotes: 3
Reputation: 364
The MySQL Socket declaration should be located under [mysqld]
in your my.cnf
(located at /etc/mysql/my.cnf
in Debian flavours). MySQL Socket information can also be found using the following command:
mysql> show variables like 'socket';
+-----------------------------------------+-------------------------------+
| Variable_name | Value |
+-----------------------------------------+-------------------------------+
| socket | /yourpath/mysql.sock |
+-----------------------------------------+-------------------------------+
1 rows in set (0.00 sec)
Update the environment variable for the current session and execute the command, eg:
export MYSQL_UNIX_PORT=/home/mysql123/tmp/mysql.sock
./mysql_secure_installation
Upvotes: 12
Reputation: 23171
Make sure you start mysql or mariadb, for example:
sudo systemctl start mariadb.service
sudo systemctl enable mariadb.service
Upvotes: 14
Reputation: 157
I had this same error happen, and it turns out I had stopped the MySQL service and forgotten to restart it. So you may want to check the status of the mysql service using a command like:
mysqladmin -u root -p status
If you get an error, it means MySQL is not running, and you can start the MySQL service. Or, if you prefer, you can recklessly attempt to start the service without first checking its status (which won't work if it's already running) using one of these commands:
/etc/init.d/mysql start
service mysql start
Replace mysqld
with mysqld
if your system is using that version of MySQL.
Upvotes: 3
Reputation: 884
You can also make a symlink to the socket file and then remove it:
ln -s /home/mysqk123/tmp/mysql.sock /var/lib/mysql/mysql.sock
mysql_secure_installation # Do your stuff
rm -rf /var/lib/mysql/mysql.sock
Upvotes: 5
Reputation: 29759
Since this utility is meant to be used over a standard installation, and because it seems to accept no parameter, I see very few options:
mysql_secure_installation
so that it uses your custom location. If I understand it correctly, the script creates a temporary configuration file as ./.my.cnf.$$
($$
is the pid) around line 46 in the make_config
subroutine.Modify as follows: (disclaimer: not tested :)
make_config() {
echo "# mysql_secure_installation config file" >$config
echo "[mysql]" >>$config
echo "user=root" >>$config
echo "password='$rootpass'" >>$config
# add the line below
echo "socket=/home/mysqk123/tmp/mysql.sock" >>$config
}
Again, this script is meant to be used on a standard, out-of-the box installation. Tell your boss (or your client) that if you were able to configure MySQL to use a non-standard socket location, you are also able to run by hand simple commands such as deleting accounts and setting passwords.
Upvotes: 17