-
Notifications
You must be signed in to change notification settings - Fork 85
Build and run automation
The below instructions are maybe slightly outdated.
NOTE: If you want to run Grin in a container, try the Grin Docker image instead.
To get an automated build of grin and run the server, pull changes from github, compile and restart, then run grin as a service. Tested on both Ubuntu 16.04 and Fedora 28.
Follow the instructions in the build docs and ensure that you have the server running properly. You should end up with a .grin directory in your home folder.
Edit the file that manages a 'Grin Floonet node' service:
sudo nano /etc/systemd/system/grin-floonet.service
Paste this into the file:
[Unit]
Description=Grin Floonet node
After=network.target
[Service]
WorkingDirectory=/home/ubuntu/.grin/
User=ubuntu
Group=ubuntu
PrivateDevices=yes
Type=simple
ExecReload=/bin/kill -HUP $MAINPID
KillMode=mixed
KillSignal=SIGTERM
TimeoutStopSec=60
ExecStart=/home/ubuntu/mimblewimble/grin/target/release/grin --floonet
Restart=on-failure
RestartSec=30
[Install]
WantedBy=multi-user.target
Alias=grin-floonet.service
Every time you edit this file, you need to tell systemd to reload:
systemctl daemon-reload
Now try to start the server:
sudo systemctl start grin-floonet
And check to see if it's running:
ps aux | grep grin
That should give you two lines of output like this:
ubuntu 19175 0.4 0.6 188040 54208 ? Ssl 17:45 0:07 /home/ubuntu/mimblewimble/grin/target/release/grin --floonet
ubuntu 27481 0.0 0.0 12944 1028 pts/0 S+ 18:11 0:00 grep --color=auto grin
If you use SELinux in Enforcing mode, the first time you are going to run grin via systemd is going to fail with permission errors. You can grab a profile of those permission errors using audit2allow
, create a SELinux policy module for grin, and add that module in SELinux's policies.
# capture grin AVC denials in a file
(sudo audit2allow -w -a | ausearch -c grin) > denials.log
# create a policy module out of the captured denials
# avoid piping audit2allow to itself due to https://bugs.centos.org/view.php?id=14220
cat denials.log | audit2allow -M grin
# set the module in SELinux's policies
sudo semodule -i grin.pp
Copy this text into a nightly-update.sh
in the same directory as the above:
#!/bin/sh
cd /home/ubuntu/mimblewimble/grin
git pull
cargo build --release
sudo systemctl restart grin-floonet
If you want to be pedantic and build from scratch every time, you can also insert cargo clean
before cargo build --release
.
You can set up cron jobs for you the current user by executing:
crontab -e
This will open an editor and let you edit the cron file of the current user. Paste this onto the bottom of the file:
0 2 * * * /home/ubuntu/mimblewimble/nightly-update.sh 1> /home/ubuntu/mimblewimble/nightly-update.log 2> /home/ubuntu/mimblewimble/nightly-update.log
The above puts either success or fail debug output into a file in your main directory. Alternatively, if mail is enabled on your host, you can also have the results emailed to you:
0 2 * * * /home/ubuntu/mimblewimble/nightly-update.sh 2>&1 | mail -s "grin update FAIL" you@yourdomain.com
This runs the script from the previous step at 2 am UTC. Please adjust this time with some randomness so your node does not restart at the same time as everyone else.
Later, after your chosen time of day has passed, you can check that all is working as expected. If you run ps aux | grep grin
, you should get one output line that is something like:
ubuntu 13065 0.5 1.0 206492 85232 ? Ssl 02:00 5:30 /home/ubuntu/mimblewimble/grin/target/release/grin --floonet
That means the server is running. Now also check that the latest version was built by running:
ls -l ~/mimblewimble/grin/target/release/grin
That should make it all set to compile and restart every night. Enjoy!
Basics
- Getting Started
- User Documentation
- MimbleWimble
- FAQ
- Planned releases (Roadmap)
- Code of Conduct
Contributing
- Contributing Guide
- Code Structure
- Code coverage and metrics
- Code Reviews and Audits
- Adding repos to /mimblewimble
Development
Mining
Infrastructure
Exchange integrations
R&D
Grin Community
Grin Governance
Risk Management
Grin Internals
- Block Header Data Structure
- Detailed validation logic
- P2P Protocol
Misc