Configureu Firefox Sync Server a Debian 9 o Ubuntu 16.04

Firefox Sync és una funció de sincronització del navegador que us permet compartir les vostres dades i preferències (com ara les vostres adreces d'interès, l'historial, les contrasenyes, les pestanyes obertes i els complements instal·lats) a tots els vostres dispositius. Mozilla també ofereix una aplicació de "servidor de sincronització" per utilitzar-la amb Firefox Sync per als usuaris i empreses que prefereixen allotjar les seves pròpies dades de sincronització. Aquest article us mostra com configurar Mozilla Sync Server.

Requisits previs

  • Una instància de servidor Vultr Debian 8, Debian 9 o Ubuntu 16.04 recentment implementada.
  • Un usuari de sudo .

Instal·leu els paquets necessaris

Actualitzeu el sistema:

sudo apt-get update
sudo apt-get upgrade
sudo apt-get dist-upgrade

Per crear i executar Sync Server, haureu d'instal·lar aquests paquets:

  • python-dev
  • git
  • build-essential (Compilador C++, compilador GCC, make i altres eines necessàries).
  • sqlite3(si voleu utilitzar una base de dades MySQL en lloc de SQLite, podeu substituir el sqlite3paquet per mariadb-servero mysql-server).
  • nginx(servidor web. Depèn de tu triar quin servidor web vols utilitzar apache2o nginx).

Instal·leu els paquets:

sudo apt-get install -y git git-core python-dev python-virtualenv build-essential sqlite3 nginx

Construcció del servidor

Clonarem el repositori Git del servidor de sincronització escrivint l'ordre següent i després entrar a la carpeta:

git clone https://github.com/mozilla-services/syncserver
cd syncserver

Executeu l'ordre de compilació que descarregarà les dependències i compilarà el codi.

make build

Configuració del servidor de sincronització

La configuració del servidor de sincronització és molt senzilla, només hi ha uns quants paràmetres per canviar al fitxer de configuració ( ./syncserver.ini).

Obriu el fitxer de configuració amb el vostre editor de text preferit (per exemple nano ./syncserver.ini).

[server:main]
use = egg:gunicorn
host = 0.0.0.0
port = 5000
workers = 1
timeout = 30

[app:main]
use = egg:syncserver

[syncserver]
# This must be edited to point to the public URL of your server,
# i.e. the URL as seen by Firefox.
public_url = http://localhost:5000/

# This defines the database in which to store all server data.
#sqluri = sqlite:////tmp/syncserver.db

# This is a secret key used for signing authentication tokens.
# It should be long and randomly-generated.
# The following command will give a suitable value on *nix systems:
#
#    head -c 20 /dev/urandom | sha1sum
#
# If not specified then the server will generate a temporary one at startup.
#secret = INSERT_SECRET_KEY_HERE

# Set this to "false" to disable new-user signups on the server.
# Only request by existing accounts will be honoured.
# allow_new_users = false

# Set this to "true" to work around a mismatch between public_url and
# the application URL as seen by python, which can happen in certain reverse-
# proxy hosting setups.  It will overwrite the WSGI environ dict with the
# details from public_url.  This could have security implications if e.g.
# you tell the app that it's on HTTPS but it's really on HTTP, so it should
# only be used as a last resort and after careful checking of server config.
force_wsgi_environ = false

[browserid]
# Uncomment and edit the following to use a local BrowserID verifier
# rather than posting assertions to the mozilla-hosted verifier.
# Audiences should be set to your public_url without a trailing slash.
#backend = tokenserver.verifiers.LocalVerifier
#audiences = https://localhost:5000

# By default, syncserver will accept identity assertions issues by
# any server. You can restrict this by setting the below to a list
# of allowed issuer domains.
#allowed_issuers = www.mysite.com myfriendsdomain.org

L'adreça del vostre servidor s'ha d'especificar mitjançant el paràmetre public_url:

public_url = http://fsync.example.com

Nota : el valor predeterminat de public_url"http://localhost:5000/" funcionarà amb finalitats de prova a la vostra màquina local.

A l' sqluriopció, descomentarem i posarem la ubicació o URIque permetrà al servidor connectar la base de dades i emmagatzemar la informació:

sqluri = sqlite:////path/to/database/file.db

Si voleu utilitzar un altre tipus de base de dades:

sqluri = pymysql://username:password@db.example.com/sync

Per al secretparàmetre " ", haurem de generar una clau secreta per als testimonis d'autenticació:

head -c 20 /dev/urandom | sha1sum

Descomenteu la línia del paràmetre secret i després copieu/enganxeu la cadena retornada al paràmetre secret:

secret = db8a203aed5fe3e4594d4b75990acb76242efd35

Nota : Si no introduïu res en aquest paràmetre, el servidor en generarà un, però serà diferent cada vegada que es reiniciï.

Per al allow\_new\_usersparàmetre " ", descomenceu-lo i configureu-lo perquè truepermeti que el nostre compte es connecti al nostre servidor per primera vegada:

allow_new_users = true

Aleshores modificarem el audiencesparàmetre " " i posarem el mateix que el public_uriparàmetre " " sense oblidar-nos de descomentar la línia:

audiences = http://fsync.example.com

Finalment, només cal afegir la línia següent al final del fitxer:

forwarded_allow_ips = *

Aquesta línia us ajudarà a evitar missatges d'error i problemes d'autorització.

S'està iniciant el servidor de sincronització

Per iniciar el servidor de sincronització, podeu executar l'ordre següent:

./path/to/syncserver/local/bin/gunicorn --threads 4 --paste /path/to/syncserver/syncserver.ini &

... o aquest:

make serve &

La primera opció permet escollir la ubicació del fitxer de configuració; i també per posar l'argument --threads 4, que permet assignar més potència al servidor de sincronització.

Per iniciar el servidor cada vegada que la vostra instància arrenqui, podeu afegir la línia següent al vostre crontab escrivint l' crontab -eordre:

@reboot ./path/to/syncserver/local/bin/gunicorn --paste /path/to/syncserver/syncserver.ini &

Configuració del servidor web

Podeu utilitzar diferents servidors web compatibles amb el WSGIprotocol. Per exemple:

  • Nginx amb uWSGI.
  • Apache combinat amb mod_wsgi.

Nginx

Per a Nginx, heu d'utilitzar el servidor intermediari integrat de Nginx tal com es mostra a continuació:

server {
        listen  80;
        server_name fsync.example.com;

        location / {
                proxy_set_header Host $http_host;
                proxy_set_header X-Forwarded-Proto $scheme;
                proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
                proxy_set_header X-Real-IP $remote_addr;
                proxy_redirect off;
                proxy_read_timeout 120;
                proxy_connect_timeout 10;
                proxy_pass http://127.0.0.1:5000/;
        }
}

Nginx + uWSGI

Els usuaris de Nginx només poden utilitzar el sòcol WSGI.

Instal·lar uWSGImitjançant Pip:

pip install uwsgi

Instal·lar uWSGImitjançant la descàrrega d'un fitxer tarball d'origen:

wget https://projects.unbit.it/downloads/uwsgi-latest.tar.gz
tar zxvf uwsgi-latest.tar.gz
cd <dir>
make

Nota : Després de la compilació, tindreu un uwsgibinari al directori actual.

Un cop instal·lat, inicieu-lo amb les opcions següents:

uwsgi --plugins python27 --manage-script-name \
--mount /<location>=/path/to/syncserver/syncserver.wsgi \
--socket /path/to/uwsgi.sock

A continuació, utilitzeu la següent configuració de Nginx:

location /<location>/ {
  include uwsgi_params;
  uwsgi_pass unix:/path/to/uwsgi.sock;
}

Apache

Instal·lar mod_wsgi:

apt-get install libapache2-mod-wsgi

A continuació, utilitzeu el vhost següent:

<VirtualHost *:80>
  ServerName sync.example.com
  DocumentRoot /path/to/syncserver
  WSGIProcessGroup sync
  WSGIDaemonProcess sync user=sync group=sync processes=2 threads=25 python-path=/path/to/syncserver/local/lib/python2.7/site-packages/
  WSGIPassAuthorization On
  WSGIScriptAlias / /path/to/syncserver/syncserver.wsgi
  CustomLog /var/log/apache2/sync.example.com-access.log combined
  ErrorLog  /var/log/apache2/sync.example.com-error.log
</VirtualHost>

Configurar el client (Firefox)

Un cop instal·lat i configurat el servidor, hauríeu de configurar el client Firefox d'escriptori perquè parli amb el vostre nou servidor de sincronització. Abans de començar, si ja esteu connectat als servidors de sincronització de Firefox, heu de tancar la sessió. En cas contrari, és possible que la connexió amb el nou servidor no funcioni.

Primer, obriu una pestanya nova i introduïu l'adreça següent:

about:config

A la barra de cerca, introduïu identity.sync.tokenserver.urii canvieu el seu valor a l'URL del vostre servidor amb una ruta de token/1.0/sync/1.5:

http://sync.example.com/token/1.0/sync/1.5

Deixa un comentari

The Rise of Machines: Real World Applications of AI

The Rise of Machines: Real World Applications of AI

La Intel·ligència Artificial no està en el futur, és aquí mateix en el present. En aquest bloc Llegiu com les aplicacions d'Intel·ligència Artificial han afectat diversos sectors.

Atacs DDOS: una breu visió general

Atacs DDOS: una breu visió general

També ets víctima d'atacs DDOS i estàs confós sobre els mètodes de prevenció? Llegiu aquest article per resoldre les vostres consultes.

Us heu preguntat mai com guanyen diners els pirates informàtics?

Us heu preguntat mai com guanyen diners els pirates informàtics?

Potser haureu sentit que els pirates informàtics guanyen molts diners, però us heu preguntat mai com guanyen aquest tipus de diners? anem a discutir.

Invents revolucionaris de Google que us facilitaran la vida.

Invents revolucionaris de Google que us facilitaran la vida.

Vols veure els invents revolucionaris de Google i com aquests invents van canviar la vida de tots els éssers humans actuals? A continuació, llegiu al bloc per veure els invents de Google.

Divendres essencial: què va passar amb els cotxes impulsats per IA?

Divendres essencial: què va passar amb els cotxes impulsats per IA?

El concepte de cotxes autònoms per sortir a les carreteres amb l'ajuda de la intel·ligència artificial és un somni que tenim des de fa temps. Però malgrat les diverses promeses, no es veuen enlloc. Llegeix aquest blog per saber-ne més...

Singularitat tecnològica: un futur llunyà de la civilització humana?

Singularitat tecnològica: un futur llunyà de la civilització humana?

A mesura que la ciència evoluciona a un ritme ràpid, fent-se càrrec de molts dels nostres esforços, també augmenten els riscos de sotmetre'ns a una singularitat inexplicable. Llegeix, què pot significar per a nosaltres la singularitat.

Funcionalitats de les capes darquitectura de referència de Big Data

Funcionalitats de les capes darquitectura de referència de Big Data

Llegeix el blog per conèixer de la manera més senzilla les diferents capes de l'Arquitectura Big Data i les seves funcionalitats.

Evolució de lemmagatzematge de dades – Infografia

Evolució de lemmagatzematge de dades – Infografia

Els mètodes d'emmagatzematge de les dades que han anat evolucionant poden ser des del naixement de les dades. Aquest bloc tracta l'evolució de l'emmagatzematge de dades a partir d'una infografia.

6 avantatges sorprenents de tenir dispositius domèstics intel·ligents a les nostres vides

6 avantatges sorprenents de tenir dispositius domèstics intel·ligents a les nostres vides

En aquest món digital, els dispositius domèstics intel·ligents s'han convertit en una part crucial de les vides. A continuació, es mostren alguns avantatges sorprenents dels dispositius domèstics intel·ligents sobre com fan que la nostra vida valgui la pena i sigui més senzilla.

Lactualització del suplement de macOS Catalina 10.15.4 està causant més problemes que no pas solucions

Lactualització del suplement de macOS Catalina 10.15.4 està causant més problemes que no pas solucions

Recentment, Apple va llançar macOS Catalina 10.15.4, una actualització de suplements per solucionar problemes, però sembla que l'actualització està causant més problemes que provoquen el bloqueig de les màquines Mac. Llegiu aquest article per obtenir més informació