One of the advantages of installing python in your Synology is that you can write and schedule python scripts.
In this post I will show you how to get python 3.9 running, but in a future post I will show you how to schedule it.
Enable Home for all users
First, lets enable home for all users. That is where your python scripts will reside.
data:image/s3,"s3://crabby-images/4e5a3/4e5a3cb75d81994dd4aa2915fb16e2bcec755e2e" alt=""
Enable SSH
I recommend you to disable SSH when you are done because it disables 2 factor auth and makes your synology more vulnerable.
Go to Control Panel > Terminal & SNMP > Terminal tab:
- Check “Enable SSH service”
- Click “Apply”
data:image/s3,"s3://crabby-images/36cad/36cad2190c401075522f3e8cf57399f1245e85f3" alt=""
Run SSH
Before we run SSH, we need to know the IP of the server:
data:image/s3,"s3://crabby-images/b59bc/b59bc594c1892c6bdabba30a52657b443cd5ff52" alt=""
So now Press the windows icon and type cmd to start the cmd prompt and type:
username is your admin username.
ssh username@192.168.1.xx
Enter your admin password and you are in!
Upgrade Python
All synologies come with python 2 pre-install, but we want to use python 3. Lets upgrade it from the package center:
data:image/s3,"s3://crabby-images/4c567/4c567138ab05fe7f993f3746b171c702e3e4dd21" alt=""
You will find your python 3.9 here:
/volume1/\@appstore/Python3.9/usr/bin/python3.9
If you look in the site-packages directory, you will see it is empty:
ls /volume1/\@appstore/Python3.9/usr/lib/python3.9/site-packages
so we need to install pip.
Either add the python3.9 to PATH or specify it when installing.
Sudo makes it available for all users. Your choice.
sudo /volume1/\@appstore/Python3.9/usr/bin/python3.9 -m ensurepip
Check if it has been installed:
ls /volume1/\@appstore/Python3.9/usr/lib/python3.9/site-packages
You should see pip there:
data:image/s3,"s3://crabby-images/42d7b/42d7be358f8b3741aa6dd5b49514adff887018b0" alt=""
Update the pip, setuptools and wheel packages:
sudo /volume1/\@appstore/Python3.9/usr/bin/python3.9 -m pip install --upgrade pip setuptools wheel
And now install virtual environment:
sudo /volume1/\@appstore/Python3.9/usr/bin/python3.9 -m pip install virtualenv
and verify it is there:
ls /volume1/\@appstore/Python3.9/usr/lib/python3.9/site-packages
data:image/s3,"s3://crabby-images/c2a31/c2a3172ca305132f78688128c8f2dd8d6f654879" alt=""
Now we are going to create a folder on our home directory
mkdir el_tracker
If you now navigate to your Home folder, you will see the folder there:
data:image/s3,"s3://crabby-images/c5219/c5219cf75ab9ee549c59a063378b43e2129f2c0f" alt=""
Navigate to the folder:
cd el_tracker
and create the virtual environment:
Note: elenv is the name of our virtual environment.
python3 -m venv elenv
And now you can activate it:
source elenv/bin/activate
Now that we are inside the environment we can install the packages we need.
The easiest way to get this done is to create a requirements.txt file and save it on your el_tracker project folder.
data:image/s3,"s3://crabby-images/6d263/6d263c83b216fd091a01e7f69500d6c3be8d4e9e" alt=""
This is how the file looks like:
data:image/s3,"s3://crabby-images/65397/65397f6c44f262e79eb8a9c43bbdee9338170df2" alt=""
To get all those packages installed at once:
pip install -r requirements.txt
Now you installed everything:
- Close the cmd window
- Disable SSH
- Make sure 2FA is still enabled
and happy python coding!
Coming next….
On my next post I will show you how to schedule your python script on your NAS.