Настройте Firefox Sync Server на Debian 9 или Ubuntu 16.04

Firefox Sync е функция за синхронизиране на браузъра, която ви позволява да споделяте вашите данни и предпочитания (като вашите отметки, история, пароли, отворени раздели и инсталирани добавки) на всички ваши устройства. Mozilla също така предлага приложение "сървър за синхронизиране" за използване с Firefox Sync за потребители и фирми, които предпочитат да хостват свои собствени данни за синхронизиране. Тази статия ви показва как да настроите Mozilla Sync Server.

Предпоставки

Инсталирайте необходимите пакети

Актуализирайте системата:

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

За да изградите и стартирате Sync Server, ще трябва да инсталирате тези пакети:

  • python-dev
  • git
  • build-essential (С++ компилатор, GCC компилатор, make и други необходими инструменти).
  • sqlite3(ако искате да използвате MySQL база данни вместо SQLite, можете да замените sqlite3пакета с mariadb-serverили mysql-server).
  • nginx(уеб сървър. От вас зависи да изберете от кой уеб сървър искате да използвате apache2или nginx).

Инсталирайте пакетите:

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

Изграждане на сървъра

Ще клонираме Git хранилището на сървъра за синхронизация, като напишем следната команда и след това влезем в папката:

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

Изпълнете командата за изграждане, която ще изтегли зависимостите и ще компилира кода.

make build

Конфигурация на сървъра за синхронизиране

Конфигурацията на сървъра за синхронизация е много проста, има само няколко параметъра за промяна в конфигурационния файл ( ./syncserver.ini).

Отворете конфигурационния файл с любимия си текстов редактор (например 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

Адресът на вашия сървър трябва да бъде посочен чрез параметъра public_url:

public_url = http://fsync.example.com

Забележка : стойността по подразбиране на public_url"http://localhost:5000/" ще работи за целите на тестване на вашата локална машина.

В sqluriопцията ще декомментираме и ще поставим местоположението или URIтова ще позволи на сървъра да свърже базата данни и да съхранява информацията:

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

Ако искате да използвате друг тип DB:

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

За secretпараметъра " " ще трябва да генерираме таен ключ за токени за удостоверяване:

head -c 20 /dev/urandom | sha1sum

Декоментирайте реда на секретния параметър и след това копирайте/поставете върнатия низ в секретния параметър:

secret = db8a203aed5fe3e4594d4b75990acb76242efd35

Забележка : Ако не поставите нищо в този параметър, сървърът ще генерира такъв, но той ще бъде различен всеки път, когато сървърът се рестартира.

За allow\_new\_usersпараметъра " ", разкоментирайте го и го задайте така, че trueда позволи на нашия акаунт да се свърже с нашия сървър за първи път:

allow_new_users = true

След това ще променим audiencesпараметъра " " и ще поставим същото нещо като public_uriпараметъра " ", без да забравяме да декомментираме реда:

audiences = http://fsync.example.com

Накрая просто добавете следния ред в края на вашия файл:

forwarded_allow_ips = *

Този ред ще ви помогне да избегнете съобщения за грешки и проблеми с оторизацията.

Стартиране на Sync Server

За да стартирате сървъра за синхронизиране, можете да стартирате следната команда:

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

... или този:

make serve &

Първата опция позволява избор на местоположението на конфигурационния файл; както и да постави аргумента --threads 4, който позволява да се зададе повече мощност на сървъра за синхронизация.

За да стартирате сървъра всеки път, когато вашият екземпляр се зарежда, можете да добавите следния ред към вашия crontab, като напишете crontab -eкомандата:

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

Конфигурация на уеб сървър

Можете да използвате различни уеб сървъри, които са съвместими с WSGIпротокола. Например:

  • Nginx с uWSGI.
  • Apache комбиниран с mod_wsgi.

Nginx

За Nginx трябва да използвате вградения прокси на Nginx, както е показано по-долу:

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

Възможно е потребителите на Nginx да използват само WSGI сокета.

Инсталирайте uWSGIчрез Pip:

pip install uwsgi

Инсталирайте uWSGIчрез изтегляне на изходен tarball:

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

Забележка : След компилацията ще имате uwsgiдвоичен файл в текущата директория.

След като го инсталирате, стартирайте го със следните опции:

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

След това използвайте следната конфигурация на Nginx:

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

Apache

Инсталирайте mod_wsgi:

apt-get install libapache2-mod-wsgi

След това използвайте следния vhost:

<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>

Конфигуриране на клиента (Firefox)

След като сървърът е инсталиран и конфигуриран, трябва да конфигурирате настолен Firefox клиент да разговаря с вашия нов Sync Server. Преди да започнете, ако вече сте свързани към Firefox Sync сървъри, трябва да излезете. В противен случай връзката с новия сървър може да не работи.

Първо отворете нов раздел и въведете следния адрес:

about:config

В лентата за търсене въведете identity.sync.tokenserver.uriи променете стойността му на URL адреса на вашия сървър с път от token/1.0/sync/1.5:

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

Оставете коментар

Възходът на машините: Реални приложения на AI

Възходът на машините: Реални приложения на AI

Изкуственият интелект не е в бъдещето, тук е точно в настоящето. В този блог Прочетете как приложенията за изкуствен интелект са повлияли на различни сектори.

DDOS атаки: кратък преглед

DDOS атаки: кратък преглед

Вие също сте жертва на DDOS атаки и сте объркани относно методите за превенция? Прочетете тази статия, за да разрешите вашите запитвания.

Чудили ли сте се как хакерите печелят пари?

Чудили ли сте се как хакерите печелят пари?

Може би сте чували, че хакерите печелят много пари, но чудили ли сте се някога как печелят такива пари? нека обсъдим.

Революционни изобретения на Google, които ще улеснят живота ви.

Революционни изобретения на Google, които ще улеснят живота ви.

Искате ли да видите революционни изобретения на Google и как тези изобретения промениха живота на всяко човешко същество днес? След това прочетете в блога, за да видите изобретенията на Google.

Friday Essential: Какво се случи с колите, задвижвани от изкуствен интелект?

Friday Essential: Какво се случи с колите, задвижвани от изкуствен интелект?

Концепцията за самоуправляващи се автомобили да тръгват по пътищата с помощта на изкуствен интелект е мечта, която имаме от известно време. Но въпреки няколкото обещания, те не се виждат никъде. Прочетете този блог, за да научите повече…

Технологична сингулярност: далечно бъдеще на човешката цивилизация?

Технологична сингулярност: далечно бъдеще на човешката цивилизация?

Тъй като науката се развива с бързи темпове, поемайки много от нашите усилия, рискът да се подложим на необяснима сингулярност също нараства. Прочетете какво може да означава сингулярността за нас.

Функционалности на референтните архитектурни слоеве за големи данни

Функционалности на референтните архитектурни слоеве за големи данни

Прочетете блога, за да разберете различни слоеве в архитектурата на големи данни и техните функционалности по най-простия начин.

Еволюция на съхранението на данни – инфографика

Еволюция на съхранението на данни – инфографика

Методите за съхранение на данните може да се развиват от раждането на данните. Този блог обхваща развитието на съхранението на данни на базата на инфографика.

6 невероятни предимства от наличието на интелигентни домашни устройства в живота ни

6 невероятни предимства от наличието на интелигентни домашни устройства в живота ни

В този дигитално задвижван свят устройствата за интелигентен дом се превърнаха в решаваща част от живота. Ето няколко невероятни предимства на интелигентните домашни устройства за това как те правят живота ни струващ и по-опростен.

Актуализацията на допълнението на macOS Catalina 10.15.4 причинява повече проблеми, отколкото решава

Актуализацията на допълнението на macOS Catalina 10.15.4 причинява повече проблеми, отколкото решава

Наскоро Apple пусна macOS Catalina 10.15.4 допълнителна актуализация за отстраняване на проблеми, но изглежда, че актуализацията причинява повече проблеми, водещи до блокиране на mac машини. Прочетете тази статия, за да научите повече