Configurar o Firefox Sync Server no Debian 9 ou Ubuntu 16.04

O Firefox Sync é um recurso de sincronização do navegador que permite compartilhar seus dados e preferências (como favoritos, histórico, senhas, guias abertas e complementos instalados) em todos os seus dispositivos. A Mozilla também oferece um aplicativo "servidor de sincronização" para uso com o Firefox Sync para usuários e empresas que preferem hospedar seus próprios dados de sincronização. Este artigo mostra como configurar o Mozilla Sync Server.

Pré-requisitos

  • Uma instância do servidor Vultr Debian 8, Debian 9 ou Ubuntu 16.04 recém-implantada.
  • Um usuário sudo .

Instale os pacotes necessários

Atualize o sistema:

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

Para criar e executar o Sync Server, você precisará instalar estes pacotes:

  • python-dev
  • git
  • build-essential (Compilador C ++, compilador GCC, marca e outras ferramentas necessárias).
  • sqlite3(se você quiser usar um banco de dados MySQL em vez de SQLite, poderá substituir o sqlite3pacote por mariadb-serverou mysql-server).
  • nginx(servidor da web. Cabe a você escolher em qual servidor da web você deseja usar apache2ou nginx).

Instale os pacotes:

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

Construindo o servidor

Clonaremos o repositório Git do servidor de sincronização digitando o seguinte comando e entraremos na pasta:

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

Execute o comando build que fará o download das dependências e compilará o código.

make build

Configuração do Sync Server

A configuração do servidor de sincronização é muito simples, existem apenas alguns parâmetros para alterar no arquivo de configuração ( ./syncserver.ini).

Abra o arquivo de configuração com seu editor de texto favorito (por exemplo 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

O endereço do seu servidor deve ser especificado através do parâmetro public_url:

public_url = http://fsync.example.com

Nota : o valor padrão de public_url"http: // localhost: 5000 /" funcionará para fins de teste em sua máquina local.

Na sqluriopção, removeremos o comentário e colocaremos o local ou URIisso permitirá que o servidor conecte o banco de dados e armazene as informações:

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

Se você deseja usar outro tipo de banco de dados:

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

Para o secretparâmetro " ", teremos que gerar uma chave secreta para tokens de autenticação:

head -c 20 /dev/urandom | sha1sum

Remova o comentário da linha do parâmetro secreto e copie / cole a sequência retornada no parâmetro secreto:

secret = db8a203aed5fe3e4594d4b75990acb76242efd35

Nota : Se você não colocar nada nesse parâmetro, o servidor gerará um, mas será diferente sempre que o servidor for reiniciado.

Para o allow\_new\_usersparâmetro " ", remova o comentário e defina-o truepara permitir que nossa conta se conecte ao nosso servidor pela primeira vez:

allow_new_users = true

Em seguida, modificaremos o audiencesparâmetro " " e colocaremos o mesmo que o public_uriparâmetro " " sem esquecer de descomentar a linha:

audiences = http://fsync.example.com

Por fim, basta adicionar a seguinte linha ao final do seu arquivo:

forwarded_allow_ips = *

Essa linha ajudará a evitar mensagens de erro e problemas de autorização.

Iniciando o Sync Server

Para iniciar o servidor de sincronização, você pode iniciar o seguinte comando:

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

... ou este:

make serve &

A primeira opção permite escolher o local do arquivo de configuração; e também colocar o argumento --threads 4, que permite atribuir mais energia ao servidor de sincronização.

Para iniciar o servidor sempre que sua instância inicializar, você pode adicionar a seguinte linha ao seu crontab digitando o crontab -ecomando:

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

Configuração do servidor da Web

Você pode usar servidores da web diferentes que sejam compatíveis com o WSGIprotocolo. Por exemplo:

  • Nginx com o uWSGI.
  • Apache combinado com mod_wsgi.

Nginx

Para o Nginx, você precisa usar o proxy interno do Nginx, como mostrado abaixo:

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

É possível que os usuários do Nginx usem apenas o soquete WSGI.

Instalar uWSGIvia Pip:

pip install uwsgi

Instale uWSGIatravés do download de um tarball de origem:

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

Nota : Após a construção, você terá um uwsgibinário no diretório atual.

Depois de instalado, inicie-o com as seguintes opções:

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

Em seguida, use a seguinte configuração do Nginx:

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

Apache

Instalar mod_wsgi:

apt-get install libapache2-mod-wsgi

Em seguida, use o seguinte 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>

Configure o cliente (Firefox)

Depois que o servidor estiver instalado e configurado, você deverá configurar o cliente Firefox da área de trabalho para conversar com seu novo Sync Server. Antes de começar, se você já estiver conectado ao Firefox Sync Servers, deverá sair. Caso contrário, a conexão com o novo servidor pode não funcionar.

Primeiro, abra uma nova guia e digite o seguinte endereço:

about:config

Na barra de pesquisa, insira identity.sync.tokenserver.urie altere seu valor para o URL do seu servidor com um caminho de token/1.0/sync/1.5:

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

Deixar um comentário

A IA pode lutar contra o aumento do número de ataques de ransomware

A IA pode lutar contra o aumento do número de ataques de ransomware

Os ataques de ransomware estão aumentando, mas a IA pode ajudar a lidar com os vírus de computador mais recentes? AI é a resposta? Leia aqui para saber se é AI boone ou bane

ReactOS: Este é o futuro do Windows?

ReactOS: Este é o futuro do Windows?

ReactOS, um sistema operacional de código aberto e gratuito está aqui com a versão mais recente. Será que ela pode atender às necessidades dos usuários modernos do Windows e derrubar a Microsoft? Vamos descobrir mais sobre esse estilo antigo, mas uma experiência de sistema operacional mais recente.

Fique conectado por meio do aplicativo WhatsApp Desktop 24 * 7

Fique conectado por meio do aplicativo WhatsApp Desktop 24 * 7

O Whatsapp finalmente lançou o aplicativo Desktop para usuários de Mac e Windows. Agora você pode acessar o Whatsapp do Windows ou Mac facilmente. Disponível para Windows 8+ e Mac OS 10.9+

Como a IA pode levar a automação de processos ao próximo nível?

Como a IA pode levar a automação de processos ao próximo nível?

Leia isto para saber como a Inteligência Artificial está se tornando popular entre as empresas de pequena escala e como está aumentando as probabilidades de fazê-las crescer e dar vantagem a seus concorrentes.

A atualização do suplemento do macOS Catalina 10.15.4 está causando mais problemas do que resolvendo

A atualização do suplemento do macOS Catalina 10.15.4 está causando mais problemas do que resolvendo

Recentemente, a Apple lançou o macOS Catalina 10.15.4, uma atualização suplementar para corrigir problemas, mas parece que a atualização está causando mais problemas, levando ao bloqueio de máquinas mac. Leia este artigo para saber mais

13 Ferramentas de Extração de Dados Comerciais de Big Data

13 Ferramentas de Extração de Dados Comerciais de Big Data

13 Ferramentas de Extração de Dados Comerciais de Big Data

O que é um sistema de arquivos de registro no diário e como ele funciona?

O que é um sistema de arquivos de registro no diário e como ele funciona?

Nosso computador armazena todos os dados de uma maneira organizada conhecida como sistema de arquivos Journaling. É um método eficiente que permite ao computador pesquisar e exibir arquivos assim que você clicar em search.https: //wethegeek.com/? P = 94116 & preview = true

Singularidade tecnológica: um futuro distante da civilização humana?

Singularidade tecnológica: um futuro distante da civilização humana?

À medida que a ciência evolui em um ritmo rápido, assumindo muitos de nossos esforços, os riscos de nos sujeitarmos a uma singularidade inexplicável também aumentam. Leia, o que a singularidade pode significar para nós.

Uma visão sobre 26 técnicas analíticas de Big Data: Parte 1

Uma visão sobre 26 técnicas analíticas de Big Data: Parte 1

Uma visão sobre 26 técnicas analíticas de Big Data: Parte 1

O impacto da inteligência artificial na saúde 2021

O impacto da inteligência artificial na saúde 2021

A IA na área da saúde deu grandes saltos nas últimas décadas. Portanto, o futuro da IA ​​na área da saúde ainda está crescendo dia a dia.