The Rise of Machines: Real World Applications of AI
Umelá inteligencia nie je v budúcnosti, je tu priamo v súčasnosti V tomto blogu si prečítajte, ako aplikácie umelej inteligencie ovplyvnili rôzne sektory.
NodeBB je softvér fóra založený na Node.js. Využíva webové zásuvky na okamžité interakcie a upozornenia v reálnom čase. Zdrojový kód NodeBB je verejne hosťovaný na Github . Táto príručka vás prevedie procesom inštalácie NodeBB na novej inštancii FreeBSD 12 Vultr pomocou Node.js, MongoDB ako databázy, Nginx ako reverzného proxy a Acme.sh pre SSL certifikáty.
NodeBB vyžaduje, aby bol nainštalovaný nasledujúci softvér:
A/AAAASkontrolujte verziu FreeBSD.
uname -ro
# FreeBSD 12.0-RELEASE
Uistite sa, že váš systém FreeBSD je aktuálny.
freebsd-update fetch install
pkg update && pkg upgrade -y
Nainštalujte potrebné balíky, ak sa nenachádzajú vo vašom systéme.
pkg install -y sudo vim unzip wget git bash socat gcc8 pkgconf vips
Vytvorte si nový používateľský účet s preferovaným používateľským menom (použijeme johndoe).
adduser
# Username: johndoe
# Full name: John Doe
# Uid (Leave empty for default): <Enter>
# Login group [johndoe]: <Enter>
# Login group is johndoe. Invite johndoe into other groups? []: wheel
# Login class [default]: <Enter>
# Shell (sh csh tcsh nologin) [sh]: bash
# Home directory [/home/johndoe]: <Enter>
# Home directory permissions (Leave empty for default): <Enter>
# Use password-based authentication? [yes]: <Enter>
# Use an empty password? (yes/no) [no]: <Enter>
# Use a random password? (yes/no) [no]: <Enter>
# Enter password: your_secure_password
# Enter password again: your_secure_password
# Lock out the account after creation? [no]: <Enter>
# OK? (yes/no): yes
# Add another user? (yes/no): no
# Goodbye!
Spustite visudopríkaz a odkomentujte %wheel ALL=(ALL) ALLriadok, aby členovia wheelskupiny mohli vykonať ľubovoľný príkaz.
visudo
# Uncomment by removing hash (#) sign
# %wheel ALL=(ALL) ALL
Teraz prejdite na svojho novo vytvoreného používateľa pomocou su.
su - johndoe
POZNÁMKA: Nahraďte johndoesvojim užívateľským menom.
Nastavte časové pásmo.
sudo tzsetup
NodeBB je riadený Node.js, a preto je potrebné ho nainštalovať. Odporúča sa inštalácia aktuálnej verzie LTS Node.js.
Nainštalujte Node.js a npm.
sudo pkg install -y node10 npm-node10
Skontrolujte verzie.
node -v && npm -v
# v10.15.3
# 6.9.0
MongoDB je predvolená databáza pre NodeBB.
Nainštalujte MongoDB.
sudo pkg install -y mongodb40
Skontrolujte verziu.
mongo --version | head -n 1 && mongod --version | head -n 1
# MongoDB shell version v4.0.6
# db version v4.0.6
Povoliť a spustiť MongoDB.
sudo sysrc mongod_enable=yes
sudo service mongod start
Vytvorte databázu a používateľa pre NodeBB.
Najprv sa pripojte k MongoDB.
mongo
Prepnite na vstavanú admindatabázu.
> use admin
Vytvorte administrátora.
> db.createUser( { user: "admin", pwd: "<Enter a secure password>", roles: [ { role: "readWriteAnyDatabase", db: "admin" }, { role: "userAdminAnyDatabase", db: "admin" } ] } )
POZNÁMKA: Nahraďte zástupný symbol <Enter a secure password>vlastným vybratým heslom.
Pridajte novú databázu s názvom nodebb.
> use nodebb
Vytvorí sa databáza a kontext sa prepne na nodebb. Potom vytvorte nodebbpoužívateľa s príslušnými oprávneniami.
> db.createUser( { user: "nodebb", pwd: "<Enter a secure password>", roles: [ { role: "readWrite", db: "nodebb" }, { role: "clusterMonitor", db: "admin" } ] } )
POZNÁMKA: Zástupný symbol opäť nahraďte <Enter a secure password>vlastným zvoleným heslom.
Opustite Mongo shell.
> quit()
Reštartujte MongoDB a uistite sa, že sa môže pripojiť skôr vytvorený administrátor.
sudo service mongod restart
mongo -u admin -p your_password --authenticationDatabase=admin
Nainštalujte Nginx.
sudo pkg install -y nginx
Skontrolujte verziu.
nginx -v
# nginx version: nginx/1.14.2
Povoľte a spustite Nginx.
sudo sysrc nginx_enable=yes
sudo service nginx start
NodeBB štandardne beží na porte 4567. Aby http://example.com:4567sme sa vyhli zadávaniu , nakonfigurujeme Nginx ako reverzný proxy pre aplikáciu NodeBB. Každá požiadavka na port 80alebo 443, ak sa používa SSL, bude presmerovaná na port 4567.
Run sudo vim /usr/local/etc/nginx/nodebb.conf and populate it with the basic reverse proxy configuration below.
server {
listen [::]:80;
listen 80;
server_name forum.example.com;
root /usr/share/nginx/html;
client_max_body_size 50M;
location /.well-known/acme-challenge/ {
allow all;
}
location / {
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header Host $http_host;
proxy_hide_header X-Powered-By;
proxy_set_header X-Nginx-Proxy true;
proxy_pass http://127.0.0.1:4567;
proxy_redirect off;
# Socket.IO Support
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
}
}
In the above config, update the server_name directive with your domain/hostname.
Save the file and exit with :+W+Q.
Now we need to include nodebb.conf in the main nginx.conf file.
Run sudo vim /usr/local/etc/nginx/nginx.conf and add the following line to the http {} block.
include nodebb.conf;
Check the configuration.
sudo nginx -t
Reload Nginx.
sudo service nginx reload
Securing your forum with HTTPS is not necessary, but it will secure your site's traffic. Acme.sh is a pure unix shell software for obtaining SSL certificates from Let's Encrypt with zero dependencies.
Download and install Acme.sh.
sudo mkdir /etc/letsencrypt
git clone https://github.com/Neilpang/acme.sh.git
cd acme.sh
sudo ./acme.sh --install --home /etc/letsencrypt --accountemail your_email@example.com
cd ~
Check the version.
/etc/letsencrypt/acme.sh --version
# v2.8.1
Obtain RSA and ECDSA certificates for forum.example.com.
# RSA 2048
sudo /etc/letsencrypt/acme.sh --issue --home /etc/letsencrypt -d forum.example.com --webroot /usr/share/nginx/html --reloadcmd "sudo service nginx reload" --keylength 2048
# ECDSA/ECC P-256
sudo /etc/letsencrypt/acme.sh --issue --home /etc/letsencrypt -d forum.example.com --webroot /usr/share/nginx/html --reloadcmd "sudo service nginx reload" --keylength ec-256
Po spustení vyššie uvedených príkazov budú vaše certifikáty a kľúče v:
/etc/letsencrypt/forum.example.com./etc/letsencrypt/forum.example.com_ecc.Po získaní certifikátov z Let's Encrypt musíme nakonfigurovať Nginx na ich používanie.
Spustite sudo vim /usr/local/etc/nginx/nodebb.confznova a nakonfigurujte Nginx ako HTTPS reverzný proxy.
server {
listen [::]:443 ssl http2;
listen 443 ssl http2;
listen [::]:80;
listen 80;
server_name forum.example.com;
root /usr/share/nginx/html;
client_max_body_size 50M;
location /.well-known/acme-challenge/ {
allow all;
}
# RSA
ssl_certificate /etc/letsencrypt/forum.example.com/fullchain.cer;
ssl_certificate_key /etc/letsencrypt/forum.example.com/forum.example.com.key;
# ECDSA
ssl_certificate /etc/letsencrypt/forum.example.com_ecc/fullchain.cer;
ssl_certificate_key /etc/letsencrypt/forum.example.com_ecc/forum.example.com.key;
location / {
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header Host $http_host;
proxy_set_header X-NginX-Proxy true;
proxy_pass http://127.0.0.1:4567;
proxy_redirect off;
# Socket.IO Support
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
}
}
Skontrolujte konfiguráciu.
sudo nginx -t
Znova načítať Nginx.
sudo service nginx reload
Vytvorte koreňový adresár dokumentu.
sudo mkdir -p /usr/local/www/nodebb
Zmeňte vlastníctvo /usr/local/www/nodebbadresára na johndoe.
sudo chown -R johndoe:johndoe /usr/local/www/nodebb
Prejdite do koreňového priečinka dokumentu.
cd /usr/local/www/nodebb
Naklonujte najnovší NodeBB do koreňového priečinka dokumentu.
git clone -b v1.11.x https://github.com/NodeBB/NodeBB.git .
Spustite príkaz nastavenia NodeBB a po zobrazení výzvy odpovedzte na každú otázku.
./nodebb setup
Po dokončení nastavenia NodeBB spustite ./nodebb startmanuálne spustenie servera NodeBB.
./nodebb start
Po tomto príkaze budete mať prístup k svojej inštancii fóra NodeBB vo webovom prehliadači.
Pri ./nodebb startspustení cez , NodeBB sa po reštarte systému automaticky znova nespustí. Aby sme tomu zabránili, budeme musieť nastaviť NodeBB ako systémovú službu.
Ak je spustený, zastavte NodeBB.
./nodebb stop
Nainštalujte PM2 globálne.
sudo npm install pm2 -g
Skontrolujte verziu.
pm2 -v
# 3.5.0
Prejdite do koreňového adresára dokumentu NodeBB.
cd /usr/local/www/nodebb
Spustite NodeBB cez PM2.
pm2 start app.js
Uveďte proces NodeBB.
pm2 ls
Zistite dostupný iniciačný systém.
pm2 startup
Skopírujte a prilepte výstup tohto príkazu do CLI, aby ste nastavili svoj spúšťací hák.
Uložte si zoznam procesov.
pm2 save
To je všetko. Vaša inštancia NodeBB je teraz v prevádzke.
Umelá inteligencia nie je v budúcnosti, je tu priamo v súčasnosti V tomto blogu si prečítajte, ako aplikácie umelej inteligencie ovplyvnili rôzne sektory.
Ste aj vy obeťou DDOS útokov a máte zmätok ohľadom metód prevencie? Ak chcete vyriešiť svoje otázky, prečítajte si tento článok.
Možno ste už počuli, že hackeri zarábajú veľa peňazí, ale premýšľali ste niekedy nad tým, ako môžu zarábať také peniaze? poďme diskutovať.
Chcete vidieť revolučné vynálezy od Google a ako tieto vynálezy zmenili život každého dnešného človeka? Potom si prečítajte na blogu a pozrite si vynálezy spoločnosti Google.
Koncept samoriadených áut vyraziť na cesty s pomocou umelej inteligencie je snom, ktorý máme už nejaký čas. Ale napriek niekoľkým prísľubom ich nikde nevidno. Prečítajte si tento blog a dozviete sa viac…
Ako sa veda vyvíja rýchlym tempom a preberá veľa nášho úsilia, zvyšuje sa aj riziko, že sa vystavíme nevysvetliteľnej singularite. Prečítajte si, čo pre nás môže znamenať singularita.
Prečítajte si blog, aby ste čo najjednoduchším spôsobom spoznali rôzne vrstvy architektúry veľkých dát a ich funkcie.
Spôsoby ukladania údajov sa môžu vyvíjať už od zrodu údajov. Tento blog sa zaoberá vývojom ukladania údajov na základe infografiky.
V tomto digitálnom svete sa inteligentné domáce zariadenia stali kľúčovou súčasťou života. Tu je niekoľko úžasných výhod inteligentných domácich zariadení o tom, ako robia náš život, ktorý stojí za to žiť, a ktorý zjednodušujú.
Spoločnosť Apple nedávno vydala doplnkovú aktualizáciu macOS Catalina 10.15.4 na opravu problémov, ale zdá sa, že táto aktualizácia spôsobuje ďalšie problémy, ktoré vedú k blokovaniu počítačov Mac. Prečítajte si tento článok a dozviete sa viac