Installation guide
1. Prerequisites
- a CentOS 6,CentOS 7orCentOS 8x86_64linux distribution installed (it should also work with correponding RHEL or ScientificLinux distribution)
- (or) a Fedora 29orFedora 30x86_64linux distribution
- (or) a mageia 6ormageia 7x86_64linux distribution
- (or) an opensuse/leap:15.0,opensuse/leap:15.1,opensuse/leap:42.3x86_64linux distribution (it should also work with corresponding SLES distribution)
Portable RPMs
As we build "reasonably portable" RPM packages, it should work with any RPM based linux distribution
more recent than CentOS 6 linux distribution (2011).
We  CentOS
As we develop MetWork Framework mainly on CentOS linux distributions, this is
our recommendation if you can choose your OS.
Info
We are working right now on supporting other Linux distributions (debian, ubuntu). Please contact us if you are interested in.
- disabled SELinux
How to do that?
To disable SELinux on a CentOS Linux distribution, which is enabled by default, you have to change the file
/etc/selinux/config to set SELINUX=disabled, then reboot the system.
I don't want to disable SELinux!
It should work with enabled SELinux but we never tested so tests, comments and help are welcome.
- internet access to metwork-framework.org (on standard TCP/80 port)
Offline install?
Of course, you can deploy on a computer without internet access but you will have to build your own mirror or you will have to install correspondings RPM files manually (not difficult but a little boring).
2. Configure the metwork RPM repository
2.1 Check
First check the output of uname -a |grep x86_64. If you have nothing, you don't have a x86_64 distribution installed and you can't install MetWork on it.
2.2 Choose a version
Depending on your needs (stability versus new features), you can choose between several versions :
- released stable versions with a standard semantic versionning X.Y.Zversion number (the more stable choice), we call it released stable
- continuous integration versions of the release branch (to get future patch versions before their release), we call it continuous stable
- continuous integration of the masterbranch (to get future major and minor versions before their release), we call it continuous master
- continuous integration of the integrationbranch (the more bleeding edge choice), we call it continuous integration
For each version, you will find the BaseURL in the following table:
| Version | BaseURL | 
|---|---|
| released stable | http://metwork-framework.org/pub/metwork/releases/rpms/release_1.0/portable/ | 
| continuous stable | http://metwork-framework.org/pub/metwork/continuous_integration/rpms/release_1.0/portable/ | 
| continuous master | http://metwork-framework.org/pub/metwork/continuous_integration/rpms/master/portable/ | 
| continuous integration | http://metwork-framework.org/pub/metwork/continuous_integration/rpms/integration/portable/ | 
Want to install a released old version ?
You have to change the BaseURL and replace /release_1.0/ by /release_X.Y/. For example, use
http://metwork-framework.org/pub/metwork/releases/rpms/release_0.9/portable/
as BaseURL for installing a 0.9.Z released old version.
Want to install a < 0.9 version?
Before 0.9 version, the portable subdirectory did not exist, it was replaced
by centos6 and centos7 directory with dedicated builds inside. If you are
using a < 0.9 version, please change portable by the corresponding value.
2.3 Configure
For CentOS and Fedora distributions, to configure the metwork RPM repository,
you just have to create a new /etc/yum.repos.d/metwork.repo with the following
content (example for a released stable version):
[metwork_1_0]
name=MetWork Repository Stable
baseurl=http://metwork-framework.org/pub/metwork/releases/rpms/release_1.0/portable/
gpgcheck=0
enabled=1
metadata_expire=0
If you prefer to copy/paste something, you can do that with following root commands (still for a released stable):
cat >/etc/yum.repos.d/metwork.repo <<EOF
[metwork]
name=MetWork Repository
baseurl=http://metwork-framework.org/pub/metwork/releases/rpms/release_1.0/portable/
gpgcheck=0
enabled=1
metadata_expire=0
EOF
For Mageia distributions?
To configure the metwork RPM repository for Mageia distributions, use the following root command:
urpmi.addmedia metwork http://metwork-framework.org/pub/metwork/releases/rpms/release_1.0/portable/
For SUSE distributions?
To configure the metwork RPM repository for SUSE distributions, use the following root command:
zypper ar -G http://metwork-framework.org/pub/metwork/releases/rpms/release_1.0/portable/ metwork
Warning
Previous examples are about stable release. Be sure
to change the baseurl value if you want a "non stable" MetWork version.
2.4 Test
With a CentOS or Fedora distributions, to test the repository, you can use the command yum list "metwork*" (as root). You must get several metwork-... modules available.
For Mageia distributions?
To test the repository, you can use the command urpmq --list |grep metwork |uniq (as root). You must get several metwork-... modules available.
For SUSE distributions?
To test the repository, you can use the command zypper pa |grep metwork (as root). You must get several metwork-... modules available.
3. How to install mfdata metwork module
3.1 Minimal installation
You just have to execute the following command (as root user):
yum install metwork-mfdata
urpmi metwork-mfdata
zypper install metwork-mfdata
3.2 Full installation (all mfdata layers)
If you prefer a full installation (as root user):
yum install metwork-mfdata-full
urpmi metwork-mfdata-full
zypper install metwork-mfdata-full
3.3 Optional mfext layers
You can also add extra (optional) mfext layers.
# To install some devtools
yum install metwork-mfext-layer-python3_devtools
# To install some (base) scientific libraries
yum install metwork-mfext-layer-scientific_core
# To install java/nodejs binaries
yum install metwork-mfext-layer-nodejs
yum install metwork-mfext-layer-java
# To install some devtools
urpmi metwork-mfext-layer-python3_devtools
# To install some (base) scientific libraries
urpmi metwork-mfext-layer-scientific_core
# To install java/nodejs binaries
urpmi metwork-mfext-layer-nodejs
urpmi metwork-mfext-layer-java
# To install some devtools
zypper install metwork-mfext-layer-python3_devtools
# To install some (base) scientific libraries
zypper install metwork-mfext-layer-scientific_core
# To install java/nodejs binaries
zypper install metwork-mfext-layer-nodejs
zypper install metwork-mfext-layer-java
3.4 Optional mfext layers (from mfext add-ons)
You can also install some optional layers (provided by some mfext add-ons) in the same way and with the same repository (for official add-ons).
For example (please refer to corresponding add-on documentation)
# To install python2 support
yum install metwork-mfext-layer-python2
# To install python2 devtools
yum install metwork-mfext-layer-python2_devtools
# To install opinionated VIM with Python3 support
yum install metwork-mfext-layer-python3_vim
# To install all scientific libraries (for Python3)
yum install metwork-mfext-layer-python3_scientific
# To install all scientific libraries (for Python2)
yum install metwork-mfext-layer-python2_scientific
# To install "machine learning" Python3 libraries
yum install metwork-mfext-layer-python3_ia
# To install "mapserver" stuff for Python3
yum install metwork-mfext-layer-python3_mapserverapi
# [...]
# To install python2 support
urpmi metwork-mfext-layer-python2
# To install python2 devtools
urpmi metwork-mfext-layer-python2_devtools
# To install opinionated VIM with Python3 support
# for CentOS or Fedora (see above note for other distributions)
urpmi metwork-mfext-layer-python3_vim
# To install all scientific libraries (for Python3)
urpmi metwork-mfext-layer-python3_scientific
# To install all scientific libraries (for Python2)
urpmi metwork-mfext-layer-python2_scientific
# To install "machine learning" Python3 libraries
urpmi metwork-mfext-layer-python3_ia
# To install "mapserver" stuff for Python3
urpmi metwork-mfext-layer-python3_mapserverapi
# [...]
# To install python2 support
zypper install metwork-mfext-layer-python2
# To install python2 devtools
zypper install metwork-mfext-layer-python2_devtools
# To install opinionated VIM with Python3 support
# for CentOS or Fedora (see above note for other distributions)
zypper install metwork-mfext-layer-python3_vim
# To install all scientific libraries (for Python3)
zypper install metwork-mfext-layer-python3_scientific
# To install all scientific libraries (for Python2)
zypper install metwork-mfext-layer-python2_scientific
# To install "machine learning" Python3 libraries
zypper install metwork-mfext-layer-python3_ia
# To install "mapserver" stuff for Python3
zypper install metwork-mfext-layer-python3_mapserverapi
# [...]
4. How to start all metwork modules (after installation)
# As root user
service metwork start
Note
If your distribution does not provide service command, you can use
systemctl start metwork.service instead or /etc/rc.d/init.d/metwork start
(if you don't have a systemd enabled machine or container).
5. FAQ
5.1 I don't want to install in /opt!
Sorry, but it's our packaging choice in it is coherent with Linux FHS. We have no plan to change that.
If you are really not happy with that, you can install MetWork where you want by recompiling it.