Възходът на машините: Реални приложения на AI
Изкуственият интелект не е в бъдещето, тук е точно в настоящето. В този блог Прочетете как приложенията за изкуствен интелект са повлияли на различни сектори.
Firefox Sync е функция за синхронизиране на браузъра, която ви позволява да споделяте вашите данни и предпочитания (като вашите отметки, история, пароли, отворени раздели и инсталирани добавки) на всички ваши устройства. Mozilla също така предлага приложение "сървър за синхронизиране" за използване с Firefox Sync за потребители и фирми, които предпочитат да хостват свои собствени данни за синхронизиране. Тази статия ви показва как да настроите Mozilla Sync Server.
Актуализирайте системата:
sudo apt-get update
sudo apt-get upgrade
sudo apt-get dist-upgrade
За да изградите и стартирате Sync Server, ще трябва да инсталирате тези пакети:
python-devgitbuild-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 = *
Този ред ще ви помогне да избегнете съобщения за грешки и проблеми с оторизацията.
За да стартирате сървъра за синхронизиране, можете да стартирате следната команда:
./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, както е показано по-долу:
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 да използват само 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;
}
Инсталирайте 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 клиент да разговаря с вашия нов 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
Изкуственият интелект не е в бъдещето, тук е точно в настоящето. В този блог Прочетете как приложенията за изкуствен интелект са повлияли на различни сектори.
Вие също сте жертва на DDOS атаки и сте объркани относно методите за превенция? Прочетете тази статия, за да разрешите вашите запитвания.
Може би сте чували, че хакерите печелят много пари, но чудили ли сте се някога как печелят такива пари? нека обсъдим.
Искате ли да видите революционни изобретения на Google и как тези изобретения промениха живота на всяко човешко същество днес? След това прочетете в блога, за да видите изобретенията на Google.
Концепцията за самоуправляващи се автомобили да тръгват по пътищата с помощта на изкуствен интелект е мечта, която имаме от известно време. Но въпреки няколкото обещания, те не се виждат никъде. Прочетете този блог, за да научите повече…
Тъй като науката се развива с бързи темпове, поемайки много от нашите усилия, рискът да се подложим на необяснима сингулярност също нараства. Прочетете какво може да означава сингулярността за нас.
Прочетете блога, за да разберете различни слоеве в архитектурата на големи данни и техните функционалности по най-простия начин.
Методите за съхранение на данните може да се развиват от раждането на данните. Този блог обхваща развитието на съхранението на данни на базата на инфографика.
В този дигитално задвижван свят устройствата за интелигентен дом се превърнаха в решаваща част от живота. Ето няколко невероятни предимства на интелигентните домашни устройства за това как те правят живота ни струващ и по-опростен.
Наскоро Apple пусна macOS Catalina 10.15.4 допълнителна актуализация за отстраняване на проблеми, но изглежда, че актуализацията причинява повече проблеми, водещи до блокиране на mac машини. Прочетете тази статия, за да научите повече