Mysql2Elastic gives you the ability to migrate all tables or selected tables from a MySql Database and convert them to ElasticSearch Index(s) it is very simple to use using either the command line application or the simple Web interface.
Migrations can be done using a live database (Local or Remote) or by providing a SQL file.
Simply put this is a set of tools for migrating MySql to ElasticSearch
As Development is on going some tables may not be migrated correctly to assist with development i would appreciate if you could raise a issue on GitHub, Pull requests will be happily accepted if they are of good quality and improve functionality or fix bugs/issues.Simply clone the repository on either your local machine or server;
```git clone https://github.com/wallermadev/MySQL-To-ElasticSearch.git```
Enter the cloned directory;
cd MySQL-To-ElasticSearch.git
install the dependancies using composer;
php composer.phar install
Edit configuration to use your ElasticSearch Installation (Skip this step if you are using the web interface);
nano config/Elastic.conf
Update IP, Port and login credentials (if Applicable) To that of your ElasticSearch Instance this step is only needed if you intend to use MySql2Elastic using the command line interface as a configuration file will be generated if you are using the web interface.
Edit configuration to use your Mysql Installation (Skip this step if you are using the web interface);
nano config/Mysql.conf
Update IP, Port and login credentials (if Applicable) To that of your MySql Server this step is only needed if you intend to use MySql2Elastic using the command line interface as a configuration file will be generated if you are using the web interface.
Additional configuration such as memory limit, maximum execution time, Error logging options etc... can be set inside;
nano config/extra.conf
I will update this section as and when i am happy with progress.
If you are using the Web interface run the shell script startServer.sh using the command;```bash startServer.sh```
You can use screen to run the server in the background using;
screen ./startServer.sh
If the server successfully started you can access it via your web browser on port 4321 for example if you are running the server on your local machine you can access the web interface by visiting;
link-: http://127.0.0.1:4321
From here follow the on screen instructions to configure the the credentials for the target ElasticSearch Installation and Host Mysql Installation after the initial configuration you are able to set Additional options and Edit the ElasticSearch/Mysql Configuration by accessing the "Configuration" In the main menu.
If you have configured everything correctly the status in either the status widget or on the status page will display GREEN with the message "Everything Connected fine" the status feature works by polling the server and logging in -- if there is a error while doing do The status will display RED with a message regarding what went wrong, there are also warning statuses which are yellow these are rare and are usually related to a slow connection/reply to the host or target servers you can continue with error but do so at your own risk!
If everything went well and your status is not showing any errors you will be redirected to a page to select the database on the MySql host when selected a select box will be displayed with all possible tables that can be migrated you can select any amount however for best result only migrate between 1-5 at a time.
After the database has been selected and you have chosen the tables you want to migrate click the Migrate Button A modal will appear and show migration progress if any as it progresses the "Log Box" will update showing Progress/Errors/Warnings.
Congratulations! If all went well you will have successfully migrated your Mysql Database/Tables and data to ElasticSearch!
If a unexpected error occured please check the "Common Problems" Section for a solution if a solution can not be found please submit a Issue and i will try assist you the best i can.
I am working on this project in my freetime to add to my portfolio the end goal is the ability to provide full migration of mysql tables to ElasticSearch With both a web interface and commandline tools.
Im more than happy to consider feature requests but currently the main priority is perfecting migration from MySql to ElasticSearch -- if you have a suggestion which will help this process i am happy to forfil your request.
Unable to access Web Interface while Running the MySql2Elastic on a cloud based service (Amazon EC2, Google Compute)
Usually this is to do with the security group on the instance try allowing incoming connection to port 4321 and trying again.
Unable to Connect to Host MySql or Target ElasticSearch Servers
Check remote connections are allowed on both if using a cloud based service check your outgoing and incoming ports.
Table has not been migrated correctly or is missing data
Please send me more details so i can investigate the issue and improve the application, You may also provide a pull request.
Unable to run startServer.sh
Check the shell script has a execution bit if not add one using chmod +x startServer.sh
startServer.sh does not start a server correction
Ensure PHP 5.6+ Is installed and Composer ran successfully.