38 KiB
Manuale di DevOps
Questa guida ti aiuterà a capire lo stack della nostra infrastruttura e come gestiamo le nostre piattaforme. Anche se questa guida non ha dettagli esaustivi per tutte le operazioni, può essere utilizzata come riferimento per la comprensione dei sistemi.
Let us know if you have feedback or queries and we will be happy to clarify.
Flight Manual - Code Deployments
This repository is continuously built, tested, and deployed to separate sets of infrastructure (Servers, Databases, CDNs, etc.).
Questo prevede tre fasi da seguire in sequenza:
- I nuovi cambiamenti (sia risoluzioni di bug che nuove caratteristiche) sono aggiunti al branch principale di sviluppo (
main) tramite pull requests. - Queste modifiche sono testate da una serie di test automatizzati.
- Una volta che i test sono superati, rilasciamo le modifiche (o aggiornamenti se necessario) alle distribuzioni sulla nostra infrastruttura.
Building the codebase - Mapping Git Branches to Deployments
In genere, si fa un merge di main (il ramo di sviluppo di default) nel branch prod-staging una volta al giorno, e questo è rilasciato in una infrastruttura isolata.
Questa è una release intermedia per i nostri sviluppatori e collaboratori volontari. È anche noto come il nostro rilascio di "staging" o "beta".
È identico al nostro ambiente di produzione live su freeCodeCamp.org, a parte il fatto che utilizza un set separato di database, server, web-proxies, ecc. Questo isolamento ci permette di testare lo sviluppo continuo e le caratteristiche in uno scenario come quello di "produzione", senza influenzare gli utenti regolari delle principali piattaforme di freeCodeCamp.org.
Una volta che il team di sviluppo @freeCodeCamp/dev-team è soddisfatto dei cambiamenti nella piattaforma di staging, questi cambiamenti sono spostati ogni pochi giorni al branch prod-current.
Questa è la versione finale che sposta le modifiche alle nostre piattaforme di produzione su freeCodeCamp.org.
Testing changes - Integration and User Acceptance Testing
Adottiamo vari livelli di integrazione e test di accettazione per verificare la qualità del codice. Tutti i nostri test sono fatti con software come GitHub Actions CI e Azure Pipelines.
We have unit tests for testing our challenge solutions, Server APIs, and Client User interfaces. Questi ci aiutano a testare l'integrazione tra i diversi componenti.
[!NOTE] We are also in the process of writing end user tests which will help in replicating real-world scenarios like updating an email or making a call to the API or third-party services.
Tutti questi test aiutano a evitare che i problemi si ripetano e assicurano di non introdurre dei bug mentre si lavora su un altro bug o una nuova funzionalità.
Deploying Changes - Pushing changes to servers
Abbiamo configurato un software di consegna continua per inviare modifiche ai nostri server di sviluppo e produzione.
Una volta che le modifiche sono inviate ai branch di rilascio protetti, una pipeline di build viene attivata automaticamente per il branch. Le pipeline di build sono responsabili della compilazione degli artefatti e di conservarli in un deposito di stoccaggio per un uso successivo.
La pipeline di build continua ad attivare una corrispondente pipeline di rilascio se completa un'esecuzione riuscita. The release pipelines are responsible for collecting the build artifacts, moving them to the servers, and going live.
The statuses of builds and releases are available here.
Trigger a Build, Test, and Deploy
Currently, only members of the developer team can push to the production branches. Le modifiche ai branch production-* possono avvenire solo tramite il merge fast-forward all'upstream.
[!NOTE] In the upcoming days, we would improve this flow to be done via pull requests, for better access management and transparency.
Pushing changes to Staging Applications
-
Configura correttamente i tuoi remotes.
git remote -vRisultati:
origin git@github.com:raisedadead/freeCodeCamp.git (fetch) origin git@github.com:raisedadead/freeCodeCamp.git (push) upstream git@github.com:freeCodeCamp/freeCodeCamp.git (fetch) upstream git@github.com:freeCodeCamp/freeCodeCamp.git (push) -
Assicurati che il tuo branch
mainsia pulito e sincronizzato con la fonte (upstream).git checkout main git fetch --all --prune git reset --hard upstream/main -
Controlla che i test GitHub CI siano superati nel branch
maindell'upstream.I test di integrazione continua dovrebbero essere verdi ed essere superati per il branch
main. Clicca sulla spunta verde vicino all'hash del commit guardando il codice del branchmain.Controllare lo stato sulle GitHub Actions (screenshot)
Se questo fallisce, dovresti fermarti e investigare gli errori.
-
Conferma di essere in grado di fare il build del repository localmente.
pnpm run clean-and-develop -
Sposta cambiamenti da
mainaprod-stagingcon un merge fast-forwardgit checkout prod-staging git merge main git push upstream[!NOTE] You will not be able to force push and if you have re-written the history in any way, these commands will error out.
Se lo fanno, potresti aver fatto qualcosa in modo errato e dovresti solo ricominciare da capo.
Gli step precedenti attiveranno automaticamente l'esecuzione della pipeline di build per il ramo prod-staging. Una volta completata la build, gli artefatti vengono salvati come file .zip in un archivio per essere recuperati e utilizzati in seguito.
La pipeline di rilascio viene attivata automaticamente quando un nuovo artefatto è disponibile dalla pipeline di build connessa. For staging platforms, this process does not involve manual approval, and the artifacts are pushed to the Client CDN and API servers.
Pushing changes to Production Applications
Il processo è per lo più lo stesso delle piattaforme di staging, con la messa in atto di alcuni controlli aggiuntivi. Questo è solo per essere sicuri: non possiamo permetterci di rompere nulla su freeCodeCamp.org dato che può vedere centinaia di utenti che lo utilizzano in qualsiasi momento.
| NON eseguire questi comandi a meno che non sia stato verificato che tutto funziona sulla piattaforma di staging. Non dovresti bypassare o saltare alcun test di staging prima di procedere ulteriormente. |
|---|
-
Assicurati che il tuo ramo
prod-stagingsia pulito e sincronizzato con la fonte.git checkout prod-staging git fetch --all --prune git reset --hard upstream/prod-staging -
Sposta cambiamenti da
prod-stagingaprod-currentcon un merge fast-forwardgit checkout prod-current git merge prod-staging git push upstream[!NOTE] You will not be able to force push and if you have re-written the history in any way, these commands will error out.
Se lo fanno, potresti aver fatto qualcosa in modo errato e dovresti solo ricominciare da capo.
Gli step precedenti attiveranno automaticamente l'esecuzione della pipeline di build per il ramo prod-current. Una volta che un artefatto di build è pronto, attiverà un avvio della pipeline di rilascio.
Misure supplementari per le azioni dello Staff
Once a release run is triggered, members of the developer staff team will receive an automated manual intervention email. Possono approvare o rifiutare l'esecuzione del rilascio.
Se le modifiche funzionano bene e sono state testate sulla piattaforma di staging, allora possono essere approvate. L’approvazione deve essere rilasciata entro 4 ore dall’attivazione del rilascio prima di essere respinta automaticamente. Un membro dello staff può riattivare il rilascio manualmente per gli avvi rifiutati, o attendere il prossimo ciclo di rilascio.
Per uso dello staff:
| Controlla la tua email per un link diretto o vai alla dashboard di rilascio dopo che la build è completata. |
|---|
Una volta che uno dei membri dello staff approva una release, la pipeline porterà i cambiamenti live ai CDN di produzione e ai server API di freecodecamp.org.
Build, Test and Deployment Status
Ecco lo stato attuale di test, build e deployment del codebase.
| Ramo | Test unitari | Test di integrazione | Build & rilasci |
|---|---|---|---|
main |
- | ||
prod-staging |
Azure Pipelines | ||
prod-current |
Azure Pipelines | ||
prod-next (sperimentale, futuro) |
- | - | - |
Early Access and Beta Testing
Ti diamo il benvenuto al test di queste versioni in modalità "public beta testing" e all'accesso anticipato alle funzionalità imminenti delle piattaforme. A volte queste funzionalità/modifiche sono indicate come next, beta, staging, ecc. in modo intercambiabile.
Your contributions via feedback and issue reports will help us in making the production platforms at freeCodeCamp.org more resilient, consistent, and stable for everyone.
Ti ringraziamo se vorrai segnalare i bug che incontrerai aiutandoci a migliorare freeCodeCamp.org. Sei un grande!
Identifying the Upcoming Version of the Platforms
Currently, a public beta testing version is available at:
| Applicazione | Lingua | URL |
|---|---|---|
| Learn | Inglese | https://www.freecodecamp.dev |
| Spagnolo | https://www.freecodecamp.dev/espanol | |
| Cinese | https://www.freecodecamp.dev/chinese | |
| News | Inglese | https://www.freecodecamp.dev/news |
| Forum | Inglese | https://forum.freecodecamp.dev |
| Cinese | https://freecodecamp.dev/chinese/forum | |
| API | - | https://api.freecodecamp.dev |
[!NOTE] Il nome del dominio è diverso da
freeCodeCamp.org. Questo è intenzionale per prevenire l'indicizzazione dai motori di ricerca e creare confusione per i normali utenti della piattaforma.The above list is not exhaustive of all the applications that we provision. Also, not all language variants are deployed in staging to conserve resources.
Identifying the Current Version of the Platforms
La versione attuale della piattaforma è sempre disponibile su freeCodeCamp.org.
Il team di sviluppo fa un merge dei cambiamenti dal ramo prod-staging a prod-current quando rilascia dei cambiamenti. Il commit superiore dovrebbe essere quello che si vede live sul sito.
È possibile identificare la versione esatta distribuita visitando i registri di compilazione e distribuzione disponibili nella sezione stato. Alternatively, you can also ping us in the contributors chat room for a confirmation.
Known Limitations
Ci sono alcune limitazioni e compromessi noti quando si utilizza la versione beta della piattaforma.
-
All data / personal progress on these beta platforms will NOT be saved or carried over to production
Gli utenti nella versione beta avranno un account separato dalla produzione. La versione beta utilizza un database fisicamente separato dalla produzione. Questo ci dà la possibilità di prevenire qualsiasi perdita accidentale di dati o modifiche. The dev-team may purge the database on this beta version as needed.
-
The beta platforms do not provide any assurances regarding uptime and reliability
Il deploy dovrebbe essere frequente e in iterazioni rapide, talvolta più volte al giorno. As a result, there will be unexpected downtime at times or broken functionality on the beta version.
-
To ensure the effectiveness of the fix, it is advised not to direct regular users to this site for verification purposes.
Il sito beta ha il solo scopo di supportare lo sviluppo locale e il testing, nient'altro. Non è una promessa di ciò che sta arrivando, ma un assaggio di ciò a cui si sta lavorando.
-
Sign in page may look different than production
Usiamo un test tenant per freeCodeCamp.dev su Auth0, e quindi non abbiamo l'abilità di impostare un dominio personalizzato. Questo fa sì che tutte le callback di reindirizzamento e la pagina di login appaiano su un dominio predefinito come:
https://freecodecamp-dev.auth0.com/. Questo non ha effetto sulle funzionalità ed è quanto più vicino possiamo arrivare alla produzione.
Reporting issues and leaving feedback
Per favore apri nuove issue per discutere e segnalare bug.
Puoi inviare un'email a dev[at]freecodecamp.org se hai domande. Come sempre tutte le vulnerabilità di sicurezza dovrebbero essere segnalate a security[at]freecodecamp.org invece che al tracker pubblico o nel forum.
Flight Manual - Server Maintenance
Warning
- Questa guida è rivolta solo ai membri dello staff di freeCodeCamp.
- Queste istruzioni non devono essere considerate esaustive, per favore usa cautela.
Come membro dello staff, potrebbe esserti stato dato accesso ai nostri fornitori di servizi cloud come Azure, Digital Ocean, ecc.
Ecco alcuni utili comandi che puoi usare per lavorare sulle Virtual Machine (VM), per fare manutenzione o faccende generali.
Get a list of the VMs
[!NOTE] While you may already have SSH access to the VMs, that alone will not let you list VMs unless you have been granted access to the cloud portals as well.
Azure
Installa Azure CLI az: https://docs.microsoft.com/en-us/cli/azure/install-azure-cli
(Una volta sola) Installa su macOS con
homebrew:
brew install azure-cli
(Una volta sola) Login:
az login
Ottieni una lista dei nomi delle VM e degli indirizzi IP:
az vm list-ip-addresses --output table
Digital Ocean
Installa Digital Ocean CLI doctl: https://github.com/digitalocean/doctl#installing-doctl
(One volta sola) Installa su macOS con
homebrew:
brew install doctl
(Una Volta) Login:
Autenticazione e cambio di contesto: https://github.com/digitalocean/doctl#authenticating-with-digitalocean
doctl auth init
Ottieni una lista dei nomi delle VM e degli indirizzi IP:
doctl compute droplet list --format "ID,Name,PublicIPv4"
Spin New Resources
Stiamo lavorando per creare il nostro setup IaC, e mentre stiamo lavorando su quello puoi usare il portale di Azure o il CLI di Azure per creare nuove macchine virtuali e altre risorse.
[!TIP] Non importa cosa usi per creare nuove risorse, abbiamo alcuni utili file di configurazione cloud-init per aiutarti a fare provisioning di base, come installare docker o aggiungere le chiavi SSH, ecc.
Keep VMs Updated
Dovresti tenere aggiornate le VM eseguendo update e upgrade. This will ensure that the virtual machine is patched with the latest security fixes.
[!WARNING] Prima di eseguire questi comandi:
- Make sure that the VM has been provisioned completely and that there are no post-install steps running.
- Se stai aggiornando pacchetti su una VM che sta già servendo una applicazione, assicurati che l'app sia stata fermata e salvata. L'aggiornamento dei pacchetti causerà picchi di utilizzo di banda, memoria e/o CPU portando a malfunzionamenti di applicazioni in esecuzione.
Aggiorna informazioni sul pacchetto
sudo apt update
Aggiorna i pacchetti installati
sudo apt upgrade -y
Pulisci i pacchetti inutilizzati
sudo apt autoremove -y
Work on Web Servers (Proxy)
Stiamo eseguendo istanze di carico bilanciate (Azure Load Balancer) per i nostri server web. Questi server eseguono NGINX che inverte il proxy di tutto il traffico a freeCodeCamp.org da varie applicazioni in esecuzione sulle proprie infrastrutture.
La configurazione di NGINX è disponibile su questo repository.
Prima Installazione
Provisioning delle VM con il codice
-
Installa NGINX e configuralo dal repository.
sudo su cd /var/www/html git clone https://github.com/freeCodeCamp/error-pages cd /etc/ rm -rf nginx git clone https://github.com/freeCodeCamp/nginx-config nginx cd /etc/nginx -
Installa i certificati di origine di Cloudfire e la configurazione dell'applicazione di upstream.
Ottieni il certificati di origine di Cloudflare dallo storage sicuro e installa nelle posizioni richieste.
O
Sposta i certificati esistenti:
# Local scp -r username@source-server-public-ip:/etc/nginx/ssl ./ scp -pr ./ssl username@target-server-public-ip:/tmp/ # Remote rm -rf ./ssl mv /tmp/ssl ./Aggiorna le configurazioni di upstream:
vi configs/upstreams.confAggiungi/aggiorna gli indirizzi IP di sorgente/origine dell'applicazione.
-
Set up networking and firewalls.
Configura i firewall di Azure e
ufwcome necessario per indirizzi di origine d'ingresso. -
Aggiungi la VM al pool del load balancer del backend.
Configura e aggiungi regole al load balancer se necessario. Potresti anche aver bisogno di aggiungere le VM al pool del load balancer del backend.
Log e monitoraggio
-
Controlla lo stato dei servizi NGINX usando i comandi seguenti:
sudo systemctl status nginx -
I log e il monitoraggio dei server sono disponibili su:
NGINX Amplify: https://amplify.nginx.com, l'attuale dashboard per il monitoraggio. Stiamo lavorando a metriche più granulari per una osservabilità migliore
Aggiornamento Istanze (Manutenzione)
Le modifiche di configurazione alle nostre istanze NGINX sono mantenute su GitHub, queste dovrebbero essere distribuite su ogni istanza in questo modo:
- SSH nell'istanza e inserisci sudo
sudo su
- Ottieni l'ultimo codice di configurazione.
cd /etc/nginx
git fetch --all --prune
git reset --hard origin/main
- Prova e ricarica la configurazione con i segnali.
nginx -t
nginx -s reload
Work on API Instances
- Installa strumenti di generazione per i binari di node (
node-gyp) ecc.
sudo apt install build-essential
Prima Installazione
Fare il provisioning delle VM con il codice
-
Install Node LTS.
-
Install pnpm globally.
npm install -g pnpm
- Install pm2 globally.
npm install -g pm2
- Clone freeCodeCamp, set up env, and keys.
git clone https://github.com/freeCodeCamp/freeCodeCamp.git
cd freeCodeCamp
git checkout prod-current # or any other branch to be deployed
-
Create the
.envfrom the secure credentials storage. -
Install dependencies
pnpm install
- Setup pm2
logrotateand startup on boot
pm2 install pm2-logrotate
pm2 startup
- Build the server
pnpm prebuild && pnpm build:curriculum && pnpm build:server
- Start Instances
pnpm start:server
Aggiornamento Istanze (Manutenzione)
pm2 logs
pm2 monit
Aggiornamento Istanze (Manutenzione)
Ogni tanto devono essere fatti dei deployment dei cambiamenti al codice alle istanze delle API. Può essere un update continuo o un update manuale. The latter is essential when changing dependencies or adding environment variables.
[!ATTENTION] Le pipeline automatizzate al momento non gestiscono l'aggiornamento delle dipendenze. Dobbiamo fare un aggiornamento manuale prima dell'avvio di qualsiasi pipeline di deployment.
1. Manual Updates - Used for updating dependencies, env variables.
- Stop all instances
pm2 stop all
- Install dependencies
pnpm install
- Build the server
pnpm prebuild && pnpm build:curriculum && pnpm build:server
- Start Instances
pnpm start:server && pm2 logs
2. Rolling updates - Used for logical changes to code.
pnpm reload:server && pm2 logs
[!NOTE] We are handling rolling updates to code and logic via pipelines. Non dovresti aver bisogno di eseguire questi comandi. Sono qui per documentazione.
3. Updating Node
-
Install new Node version
-
Update pm2 to use the new version
pm2 update
Work on Client Instances
- Install build tools for node binaries (
node-gyp) etc.
sudo apt install build-essential
Prima installazione
Fare provisioning delle VM con il codice
-
Install Node LTS.
-
Update
npmand install PM2 and setuplogrotateand startup on bootnpm i -g npm@8 npm i -g pm2@4 npm install -g serve@13 pm2 install pm2-logrotate pm2 startup -
Clone client config, setup env and keys.
git clone https://github.com/freeCodeCamp/client-config.git client cd clientStart placeholder instances for the web client, these will be updated with artifacts from the Azure pipeline.
Todo: This setup needs to move to S3 or Azure Blob storage
echo "serve -c ../serve.json -p 50505 www" > client-start-primary.sh chmod +x client-start-primary.sh pm2 delete client-primary pm2 start ./client-start-primary.sh --name client-primary echo "serve -c ../serve.json -p 52525 www" > client-start-secondary.sh chmod +x client-start-secondary.sh pm2 delete client-secondary pm2 start ./client-start-secondary.sh --name client-secondary
Logging e monitoraggio
pm2 logs
pm2 monit
Aggiornamento istanze (Manutenzione)
Ogni tanto devono essere fatti dei deployment dei cambiamenti al codice alle istanze delle API. Può essere un update continuo o un update manuale. Il secondo è essenziane quando si cambiando dipendenze o si aggiungono variabili ambientali.
[!ATTENTION] Le pipeline automatizzate al momento non gestiscono l'aggiornamento delle dipendenze. Dobbiamo fare un aggiornamento manuale prima di ogni esecuzione della pipeline di deployment.
1. Aggiornamenti manuali - Usati per aggiornare dipendenze, variabili env.
-
Stop all instances
pm2 stop all -
Install or update dependencies
-
Start Instances
pm2 start all --update-env && pm2 logs
2. Aggiornamenti continui - usati per cambiamenti logici al codice.
pm2 reload all --update-env && pm2 logs
[!NOTE] Gli update continui a codice e logica sono gestiti dalle pipeline. Non dovresti aver bisogno di eseguire questi comandi. Sono qui per documentazione.
Work on Chat Servers
I nostri chat server sono disponibili con una configuratione HA raccomandata nella documentazione di Rocket.Chat. Il file docker-compose per questo è disponibile qui.
Avviamo istanze ridondanti di NGINX che sono loro stesse con bilanciamento di carico (Azure Load Balancer) sul cluster di Rocket.Chat. I file di configurazione NGINX sono disponibili qui.
First Install
Fare provisioning delle VM con il codice
Cluster NGINX:
-
Install NGINX and configure from repository.
sudo su cd /var/www/html git clone https://github.com/freeCodeCamp/error-pages cd /etc/ rm -rf nginx git clone https://github.com/freeCodeCamp/chat-nginx-config nginx cd /etc/nginx -
Install Cloudflare origin certificates and upstream application config.
Get the Cloudflare origin certificates from the secure storage and install at required locations.
OR
Move over existing certificates:
# Local scp -r username@source-server-public-ip:/etc/nginx/ssl ./ scp -pr ./ssl username@target-server-public-ip:/tmp/ # Remote rm -rf ./ssl mv /tmp/ssl ./Update Upstream Configurations:
vi configs/upstreams.confAdd/update the source/origin application IP addresses.
-
Set up networking and firewalls.
Configure Azure firewalls and
ufwas needed for ingress origin addresses. -
Add the VM to the load balancer backend pool.
Configure and add rules to load balancer if needed. You may also need to add the VMs to load balancer backend pool if needed.
Cluster Docker:
-
Install Docker and configure from the repository
git clone https://github.com/freeCodeCamp/chat-config.git chat cd chat -
Configure the required environment variables and instance IP addresses.
-
Run rocket-chat server
docker-compose config docker-compose up -d
Logging and Monitoring
-
Check status for NGINX service using the below command:
sudo systemctl status nginx -
Check status for running docker instances with:
docker ps
Updating Instances (Maintenance)
Cluster NGINX:
Le modifiche di configurazione alle nostre istanze NGINX sono mantenute su GitHub, queste dovrebbero essere distribuite su ogni istanza in questo modo:
-
SSH into the instance and enter sudo
sudo su -
Get the latest config code.
cd /etc/nginx git fetch --all --prune git reset --hard origin/main -
Test and reload the config with Signals.
nginx -t nginx -s reload
Cluster Docker:
-
SSH into the instance and navigate to the chat config path
cd ~/chat -
Get the latest config code.
git fetch --all --prune git reset --hard origin/main -
Pull down the latest docker image for Rocket.Chat
docker-compose pull -
Update the running instances
docker-compose up -d -
Validate the instances are up
docker ps -
Cleanup extraneous resources
docker system prune --volumesOutput:
WARNING! This will remove: - all stopped containers - all networks not used by at least one container - all volumes not used by at least one container - all dangling images - all dangling build cache Are you sure you want to continue? [y/N] ySelect yes (y) to remove everything that is not in use. This will remove all stopped containers, all networks and volumes not used by at least one container, and all dangling images and build caches.
Work on Contributor Tools
Deploy Updates
Fai ssh nella VM (hosted su Digital Ocean).
cd tools
git pull origin master
pnpm install
pnpm run build
pm2 restart contribute-app
Updating Node.js Versions on VMs
Visualizza le versioni installate di node & npm
nvm -v
node -v
npm -v
nvm ls
Installa l'ultima versione di Node.js LTC, e reinstalla i pacchetti globali
nvm install --lts --reinstall-packages-from=default
Verifica i pacchetti installati
npm ls -g --depth=0
Alias the default Node.js version to the current LTS (pinned to the latest major version)
nvm alias default 16
(Facoltativo) Disinstalla vecchie versioni
nvm uninstall <version>
[!ATTENTION] Per applicazioni client, lo script della shell non può essere fatto risorgere tra versioni di Node.js con
pm2 resurrect. Fai il deploy dei processi da zero. This should become nicer when we move to a docker-based setup.Se stai usando PM2 per processi dovresti anche richiamare le applicazione e salvare la lista di processo per un recupero automatico al riavvio.
Ottieni le istruzioni/comandi di deinstallazione con il comando unstartup e usa l'output per rimuovere i servizi systemctl
pm2 unstartup
Ottieni le istruzioni/comandi di installazione con il comando startup e usa l'output per aggiungere i servizi systemctl
pm2 startup
Comandi veloci per PM2 per elencare, far ripartire processi salvati, ecc.
pm2 ls
pm2 resurrect
pm2 save
pm2 logs
Installing and Updating Azure Pipeline Agents
See: https://docs.microsoft.com/en-us/azure/devops/pipelines/agents/v2-linux?view=azure-devops and follow the instructions to stop, remove, and reinstall agents. Approssimativamente puoi seguire gli step elencati qui.
Avrai bisogno di un PAT, che puoi ottenere da: https://dev.azure.com/freeCodeCamp-org/_usersSettings/tokens
Installing Agents on Deployment targets
Vai su Azure Devops e registra l'agente dall'inizio nei requisiti deployment groups.
[!NOTE] Dovresti eseguire gli script nella home directory, e assicurati che nessun'altra directory
azagentesista.
Updating Agents
Attualmente aggiornare gli agent richiede che siano rimossi e riconfigurati. Questo è richiesto perché possano ottenere valori PATH e altre variabili d'ambiente di sistema. Dobbiame farlo per aggiornare Node.js sulle VM target di deployment.
-
Navigate and check status of the service
cd ~/azagent sudo ./svc.sh status -
Stop the service
sudo ./svc.sh stop -
Uninstall the service
sudo ./svc.sh uninstall -
Remove the agent from the pipeline pool
./config.sh remove -
Remove the config files
cd ~ rm -rf ~/azagent
Una volta completati gli step precedenti potrai ripetere gli stesi passi per installare l'agente.
Flight Manual - Email Blast
Usiamo uno strumento CLI per inviare la nostra newsletter settimanale. Per avviare e iniziare il processo:
-
Sign in to DigitalOcean, and spin up new droplets under the
Sendgridproject. Use the Ubuntu Sendgrid snapshot with the most recent date. This comes pre-loaded with the CLI tool and the script to fetch emails from the database. With the current volume, three droplets are sufficient to send the emails in a timely manner. -
Set up the script to fetch the email list.
cd /home/freecodecamp/scripts/emails cp sample.env .envYou will need to replace the placeholder values in the
.envfile with your credentials. -
Run the script.
node get-emails.js emails.csvThis will save the email list in an
emails.csvfile. -
Break the emails down into multiple files, depending on the number of droplets you need. This is easiest to do by using
scpto pull the email list locally and using your preferred text editor to split them into multiple files. Each file will need theemail,unsubscribeIdheader. -
Switch to the CLI directory with
cd /home/sendgrid-email-blastand configure the tool per the documentation. -
Run the tool to send the emails, following the usage documentation.
-
When the email blast is complete, verify that no emails have failed before destroying the droplets.
Flight Manual - Adding news instances for new languages
Theme Changes
Utilizziamo un tema personalizzato per la nostra pubblicazione. L'aggiunta delle seguenti modifiche al tema consente l'aggiunta di nuove lingue.
- Include an
else ifstatement for the new ISO language code insetup-locale.js - Create an initial config folder by duplicating the
assets/config/enfolder and changing its name to the new language code. (en—>esfor Spanish) - Inside the new language folder, change the variable names in
main.jsandfooter.jsto the relevant language short code (enMain—>esMainfor Spanish) - Duplicate the
locales/en.jsonand rename it to the new language code. - In
partials/i18n.hbs, add scripts for the newly created config files. - Add the related language
day.jsscript from cdnjs to the freeCodeCamp CDN
Ghost Dashboard Changes
Cambia gli asset della pubblicazione andando alla dashboard di ghost > settings > general e caricando l'icona, il logo, e la copertina della pubblicazione.