Everything was fantastic until I decided to expand my digital empire to a dedicated Home Media System. I wanted to run XBMC on both computers whilst being able to share their libraries.
There is an excellent Lifehacker Guide on how to do this if you want run a MySQL database on one computer and leave it running. However the LG NAS has a built in MySQL server. Surely I can use that.
Well apparently not because LG has the port to access the MySQL database closed over a network.
It makes no sense to have a NAS fileserver and have to run a PC all the time to access a shared library.
After searching a couple of forums and learning how to install a custom firmware I came up with this work around
I hope you find it helpful. It took me a while to figure this out. If you know a quicker way please share.
STEP 1. ASSIGN A STATIC IP TO YOUR NAS
So your NAS IP does not jump around we want to lock the IP to a static number.
This is fairly straightforward.
Log on to your NAS by going: (you can find this using the NAS tools provided, or by clicking info or properties once you have mounted a volume)
NAS_IP:8000
(i.e. 100.0.0.00 etc)
Log on using your username and password.
Then go to Network -> Interface.
Next set an IP and make a note of it.
If you IP is something like
101.0.0.3
It might be an idea to set it to
101.0.0.99 so that you will easily remember it.
Ta Da. Nice and easy.
STEP 2. OPEN THE LG MySQL PORT
Enable MySQL Server
For security the MySQL port is closed on the the LG NAS. So we have to now we have to enable the MYSQL server and then open the port so XBMC can access it.
Enabling MySQL is the easy part.
Log back on to your NAS by going:
NAS_IP:8000
(i.e. 100.0.0.00 etc)
Log on using your username and password.
Go to Web Services. Enable MySQL.
Open the MySQL Port Using SSH.
Install Tantalus Firmware
The next step looks tricky but is fairly straightforward as long as you follow my instructions.
The LG default FIRMWARE does not allow you to access the files that we need to change.
The easiest way around this is to the the Tantalus Firmware. This is a custom firmware that builds opens up options like SSH (so you can access the filesystem) and a couple of other nifty features.
I installed it without any problems on my N2B1 LG-NAS, and it works on any N2R1 series models with a build for N1T1.
There is of a course a risk involved here. So BACKUP EVERYTHING. Config and Data.
If the firmware update fails it could potential swipe your drive. So make sure you are happy to continue.
Go to the Tantalus site and download the latest firmware build.
Once you have done this log back on to your NAS by going:
NAS_IP:8000
(i.e. 100.0.0.00 etc)
Log on using your username and password.
Then go to SYSTEM - FIRMWARE
Select the firmware and let it install. This should take a couple of minutes and restart the NAS.
Once it has restarted check your settings are the same and your data is still there.
Enable SSH.
Under your new settings you will notice SHELL unders Services.
Select this and then ENABLE SSH.
With this enabled we can log into the filesystem.
INTO THE RABBIT HOLE : SFTP
I am using a MAC but the theory should work well across Linux or Windows.
OSX has a rather nice SSH interface built into Terminal. For windows you will need to download PuTTY
For browsing the files I am using CYBERDUCK which will has a Windows version. So the instruction will remain the same.
First we must locate the MYSQL Configuration Settings.
To do this Open Cyber Duck
Select SFTP. Input your NAS IP address
USERNAME
root
PASSWORD
root
Click Connect.
Now navigate to the / directory. It will open in root.
Navigate to
/etc/mysql
Select the my.cnf folder
Select Edit and choose the text editor of your choice.
Then find the line 48
bind-address = 127.0.01
and change it to
bind-address = {YOUR NAS IP or 0.0.0.0 - to listen for everything}
Save it.
INTO THE RABBIT HOLE : SSH COMMAND LINE
This is where those unfamiliar with command line interfaces might get confused.
We now need to be able to issue the NAS with commands.
You can close Cyberduck
Now open your SSH Command Line program of choice. PuTTY for Windows. Or Terminal for Mac
These instructions are for terminal but you should be able to follow them in PuTTY.
Select. FILE -> OPEN REMOTE CONNECTION
In the box next to Connect Enter
ssh root@YOURNAS IP.
Hit connect.
Input your password as
root
Now input
mysql -u root -p mysql
Input your MYSQL password. This will be the one we set on at Step 2. When we enabled MySQL.
If you are unsure return to the Web Service page on the LG NAS Page.
Once entered we need to issue the following commands.
update user set host = '%' where user = 'root';
then
update db set host = '%' where user = 'root';
then
flush privileges;
then
\q
Once we have done this we then need to restart MySQL
Simple paste in
/etc/init.d/mysql restart
Now you should be able to access the port from outside the network.
Create a Database for XBMC.
With that done we now need to create a DATABASE for XBMC to use.
Return to the NAS back end and log in.
Under the new heading SERVICE MANGER you need to select PackageManager and install phpMyAdmin
This will enable you to easily setup your database.
Follow the link once the install completes.
It should be something like
http://lgnas/phpMyAdmin-LG-NAS
Login with the username
root
and password that you set at STEP 2.
Now simply create two databases
xbmc_video
xbmc_music
Then open each in turn. Go to PRIVILEGES
Add a new User
Username
xbmcHost
'Any Host'
Password
xbmc
Grant All Privileges onWildcard Name (username\_&)
Then Check All Global Privileges and click GO
STEP 3. CUSTOM DATABASE FOR XBMC
After all that this is very much the easiest step.
If you have an existing Database for XBMC. Go into Settings / Video / Export
Now navigate to
MAC HD \ Users \ YOUR USERNAME \ LIBRARY \ APPLICATION SUPPORT \ XBMC \ USERDATA
Create a file called
advancedsettings.xml
Now paste in the following information.
<advancedsettings>
<videodatabase><type>mysql</type><host>{NAS IP}</host><port>3306</port><user>xbmc</user><pass>xbmc</pass><name>xbmc_video</name></videodatabase>
<musicdatabase><type>mysql</type><host>{NAS IP}</host><port>3306</port><user>xbmc</user><pass>xbmc</pass><name>xbmc_music</name></musicdatabase>
</advancedsettings>
Click Save.
Open XBMC. Then go to setting and import your library.
You can check back using MyPHPADMIN to check the tables are populated
They will look like this if you have done everything correctly.
Trouble Shooting
One problem that cropped up during my attempts to get the NAS working was a odd error. Where I was able to import the library and it appeared correctly as above but with only 14 tables.
Checking my LOG ( user / library / logs / xbmc.log - on mac ) I found the following error
ERROR: SQL: Undefined MySQL error: Code (1071)Query: CREATE UNIQUE INDEX ix_path ON path ( strPath )
This problem is caused because the default Language the database uses UTF8 causes some glitches with certain characters. If you have actors in your database with accents on characters in their names the whole database creation process stalls and XBMC gets very confused.
The fix to this is to go into MyPHPadmin and drop the whole database and start over.
You can then create a new database for both xbmc_video then xbmc_music and use the following SQL command.
(You could also do this through SSH in terminal if you prefer)
'ALTER DATABASE `xbmc_video` DEFAULT CHARACTER SET latin1 COLLATE latin1_general_ci'
Then
ALTER DATABASE `xbmc_music` DEFAULT CHARACTER SET latin1 COLLATE latin1_general_ci
Or alternatively use the command to create and define the databases in one go.
Then
CREATE DATABASE IF NOT EXISTS xbmc_video DEFAULT CHARACTER SET latin1 COLLATE latin1_general_ci
CREATE DATABASE IF NOT EXISTS xbmc_music DEFAULT CHARACTER SET latin1 COLLATE latin1_general_ciYou can then simply restart XBMC and reimport your library.