ప్రోహోస్టర్ > బ్లాగ్ > పరిపాలన > వెర్షన్ చేయబడిన డాక్యుమెంటేషన్ సైట్ యొక్క ఉదాహరణను ఉపయోగించి వెర్ఫ్తో డైనమిక్ అసెంబ్లీ మరియు డాకర్ చిత్రాల విస్తరణ
వెర్షన్ చేయబడిన డాక్యుమెంటేషన్ సైట్ యొక్క ఉదాహరణను ఉపయోగించి వెర్ఫ్తో డైనమిక్ అసెంబ్లీ మరియు డాకర్ చిత్రాల విస్తరణ
మేము ఇప్పటికే మా GitOps సాధనం గురించి ఒకటి కంటే ఎక్కువసార్లు మాట్లాడాము. వర్ఫ్, మరియు ఈసారి మేము ప్రాజెక్ట్ యొక్క డాక్యుమెంటేషన్తో సైట్ను సమీకరించడంలో మా అనుభవాన్ని పంచుకోవాలనుకుంటున్నాము - werf.io (దాని రష్యన్ వెర్షన్ en.werf.io) ఇది సాధారణ స్టాటిక్ సైట్, కానీ దాని అసెంబ్లీ ఆసక్తికరంగా ఉంటుంది, ఇది డైనమిక్ సంఖ్యలో కళాఖండాలను ఉపయోగించి నిర్మించబడింది.
సైట్ నిర్మాణం యొక్క సూక్ష్మ నైపుణ్యాలలోకి వెళ్లండి: అన్ని వెర్షన్ల కోసం సాధారణ మెనుని రూపొందించడం, విడుదలల గురించి సమాచారంతో పేజీలు మొదలైనవి. - మా కు అక్కరలేదు. బదులుగా, డైనమిక్ అసెంబ్లీ యొక్క సమస్యలు మరియు లక్షణాలపై మరియు దానితో పాటుగా ఉన్న CI/CD ప్రక్రియలపై కొంచెం దృష్టి పెడదాం.
పరిచయం: సైట్ ఎలా పని చేస్తుంది
ప్రారంభించడానికి, werf డాక్యుమెంటేషన్ దాని కోడ్తో పాటు నిల్వ చేయబడుతుంది. ఇది సాధారణంగా ఈ కథనం యొక్క పరిధికి మించిన కొన్ని అభివృద్ధి అవసరాలను విధిస్తుంది, కానీ కనీసం ఇలా చెప్పవచ్చు:
డాక్యుమెంటేషన్ను అప్డేట్ చేయకుండా కొత్త వెర్ఫ్ ఫంక్షన్లు విడుదల చేయకూడదు మరియు దీనికి విరుద్ధంగా, డాక్యుమెంటేషన్లో ఏవైనా మార్పులు వెర్ఫ్ యొక్క కొత్త వెర్షన్ విడుదలను సూచిస్తాయి;
ప్రాజెక్ట్ చాలా ఇంటెన్సివ్ అభివృద్ధిని కలిగి ఉంది: కొత్త సంస్కరణలు రోజుకు చాలా సార్లు విడుదల చేయబడతాయి;
డాక్యుమెంటేషన్ యొక్క కొత్త వెర్షన్తో సైట్ని అమలు చేయడానికి ఏదైనా మాన్యువల్ ఆపరేషన్లు కనీసం శ్రమతో కూడుకున్నవి;
ప్రాజెక్ట్ సెమాంటిక్ విధానాన్ని అవలంబిస్తుంది సంస్కరణ, 5 స్థిరత్వ ఛానెల్లతో. విడుదల ప్రక్రియలో స్థిరత్వాన్ని పెంచే క్రమంలో ఛానెల్ల ద్వారా సంస్కరణల సీక్వెన్షియల్ పాసేజ్ ఉంటుంది: ఆల్ఫా నుండి రాక్-సాలిడ్ వరకు;
సైట్ రష్యన్ భాషా సంస్కరణను కలిగి ఉంది, ఇది ప్రధాన (అంటే, ఆంగ్ల భాష) సంస్కరణకు సమాంతరంగా "జీవిస్తుంది మరియు అభివృద్ధి చెందుతుంది" (అంటే, దాని కంటెంట్ నవీకరించబడింది).
వినియోగదారు నుండి ఈ “లోపలి వంటగది” మొత్తాన్ని దాచడానికి, అతనికి “కేవలం పని చేసే” దాన్ని అందించాము ప్రత్యేక werf సంస్థాపన మరియు నవీకరణ సాధనం అది - మల్టీవెర్ఫ్. మీరు ఉపయోగించడానికి సిద్ధంగా ఉన్న విడుదల సంఖ్య మరియు స్థిరత్వ ఛానెల్ని మీరు పేర్కొనాలి మరియు మల్టీవెర్ఫ్ ఛానెల్లో కొత్త వెర్షన్ ఉందో లేదో తనిఖీ చేస్తుంది మరియు అవసరమైతే దాన్ని డౌన్లోడ్ చేస్తుంది.
వెబ్సైట్లోని సంస్కరణ ఎంపిక మెనులో, ప్రతి ఛానెల్లో werf యొక్క తాజా వెర్షన్లు అందుబాటులో ఉన్నాయి. డిఫాల్ట్గా, చిరునామా ద్వారా werf.io/documentation తాజా విడుదల కోసం అత్యంత స్థిరమైన ఛానెల్ యొక్క సంస్కరణ తెరవబడుతుంది - ఇది శోధన ఇంజిన్ల ద్వారా కూడా సూచిక చేయబడింది. ఛానెల్ కోసం డాక్యుమెంటేషన్ ప్రత్యేక చిరునామాలలో అందుబాటులో ఉంది (ఉదాహరణకు, werf.io/v1.0-beta/documentation బీటా విడుదల కోసం 1.0).
మొత్తంగా, సైట్ కింది సంస్కరణలు అందుబాటులో ఉన్నాయి:
రూట్ (డిఫాల్ట్గా తెరవబడుతుంది),
ప్రతి విడుదల యొక్క ప్రతి క్రియాశీల నవీకరణ ఛానెల్ కోసం (ఉదాహరణకు, werf.io/v1.0-beta).
సైట్ యొక్క నిర్దిష్ట సంస్కరణను రూపొందించడానికి, సాధారణంగా, దాన్ని ఉపయోగించి కంపైల్ చేయడానికి సరిపోతుంది జెకిల్డైరెక్టరీలో అమలు చేయడం ద్వారా /docs werf రిపోజిటరీ సంబంధిత కమాండ్ (jekyll build), అవసరమైన సంస్కరణ యొక్క Git ట్యాగ్కి మారిన తర్వాత.
ఇది జోడించడానికి మాత్రమే మిగిలి ఉంది:
యుటిలిటీ (వెర్ఫ్) అసెంబ్లీ కోసం ఉపయోగించబడుతుంది;
CI/CD ప్రక్రియలు GitLab CI ఆధారంగా నిర్మించబడ్డాయి;
మరియు ఇవన్నీ కుబెర్నెట్స్లో నడుస్తాయి.
పనులు
ఇప్పుడు వివరించిన అన్ని ప్రత్యేకతలను పరిగణనలోకి తీసుకునే పనులను రూపొందిద్దాం:
ఏదైనా నవీకరణ ఛానెల్లో werf సంస్కరణను మార్చిన తర్వాత సైట్లోని డాక్యుమెంటేషన్ స్వయంచాలకంగా నవీకరించబడాలి.
అభివృద్ధి కోసం మీరు కొన్నిసార్లు చేయగలరు సైట్ యొక్క ప్రివ్యూ సంస్కరణలను వీక్షించండి.
సంబంధిత Git ట్యాగ్ల నుండి ఏదైనా ఛానెల్లో సంస్కరణను మార్చిన తర్వాత సైట్ తప్పనిసరిగా తిరిగి కంపైల్ చేయబడాలి, అయితే చిత్రాన్ని నిర్మించే ప్రక్రియలో మేము ఈ క్రింది లక్షణాలను పొందుతాము:
ఛానెల్లలోని సంస్కరణల జాబితా మారినందున, సంస్కరణ మారిన ఛానెల్ల కోసం డాక్యుమెంటేషన్ను పునర్నిర్మించడం మాత్రమే అవసరం. అన్ని తరువాత, మళ్ళీ ప్రతిదీ పునర్నిర్మాణం చాలా బాగుంది కాదు.
విడుదలల కోసం ఛానెల్ల సెట్ మారవచ్చు. ఏదో ఒక సమయంలో, ఉదాహరణకు, ఛానెల్లలో ప్రారంభ యాక్సెస్ 1.1 విడుదల కంటే స్థిరమైన సంస్కరణ ఉండకపోవచ్చు, కానీ కాలక్రమేణా అవి కనిపిస్తాయి - ఈ సందర్భంలో, మీరు అసెంబ్లీని మాన్యువల్గా మార్చకూడదా?
అది మారుతుంది అసెంబ్లీ బాహ్య డేటాను మార్చడంపై ఆధారపడి ఉంటుంది.
అమలు
ఒక విధానాన్ని ఎంచుకోవడం
ప్రత్యామ్నాయంగా, మీరు Kubernetesలో ప్రత్యేక పాడ్గా అవసరమైన ప్రతి సంస్కరణను అమలు చేయవచ్చు. ఈ ఐచ్ఛికం క్లస్టర్లోని పెద్ద సంఖ్యలో వస్తువులను సూచిస్తుంది, ఇది స్థిరమైన వెర్ఫ్ విడుదలల సంఖ్య పెరుగుదలతో పెరుగుతుంది. మరియు ఇది మరింత సంక్లిష్టమైన నిర్వహణను సూచిస్తుంది: ప్రతి సంస్కరణకు దాని స్వంత HTTP సర్వర్ మరియు చిన్న లోడ్ ఉంటుంది. వాస్తవానికి, ఇది ఎక్కువ వనరుల ఖర్చులను కూడా కలిగి ఉంటుంది.
అదే బాట పట్టాం ఒక చిత్రంలో అవసరమైన అన్ని సంస్కరణలను సమీకరించడం. సైట్ యొక్క అన్ని సంస్కరణల యొక్క సంకలనం చేయబడిన స్టాటిక్స్ NGINXతో కూడిన కంటైనర్లో ఉన్నాయి మరియు సంబంధిత విస్తరణకు ట్రాఫిక్ NGINX ప్రవేశం ద్వారా వస్తుంది. ఒక సాధారణ నిర్మాణం - స్థితిలేని అప్లికేషన్ - కుబెర్నెటెస్ని ఉపయోగించి విస్తరణను (లోడ్ను బట్టి) సులభంగా స్కేల్ చేయడానికి మిమ్మల్ని అనుమతిస్తుంది.
మరింత ఖచ్చితంగా చెప్పాలంటే, మేము రెండు చిత్రాలను సేకరిస్తున్నాము: ఒకటి ప్రొడక్షన్ సర్క్యూట్ కోసం, రెండవది డెవ్ సర్క్యూట్ కోసం అదనపు ఒకటి. అదనపు చిత్రం ప్రధాన చిత్రంతో పాటు dev సర్క్యూట్లో మాత్రమే ఉపయోగించబడుతుంది మరియు సమీక్ష కమిట్ నుండి సైట్ యొక్క సంస్కరణను కలిగి ఉంటుంది మరియు వాటి మధ్య రూటింగ్ ఇన్గ్రెస్ వనరులను ఉపయోగించి నిర్వహించబడుతుంది.
werf vs git క్లోన్ మరియు కళాఖండాలు
ఇప్పటికే పేర్కొన్నట్లుగా, డాక్యుమెంటేషన్ యొక్క నిర్దిష్ట సంస్కరణ కోసం సైట్ స్టాటిక్స్ను రూపొందించడానికి, మీరు తగిన రిపోజిటరీ ట్యాగ్కు మారడం ద్వారా నిర్మించాలి. మీరు నిర్మించే ప్రతిసారీ రిపోజిటరీని క్లోనింగ్ చేయడం ద్వారా, జాబితా నుండి తగిన ట్యాగ్లను ఎంచుకోవడం ద్వారా కూడా మీరు దీన్ని చేయవచ్చు. అయితే, ఇది కాకుండా రిసోర్స్-ఇంటెన్సివ్ ఆపరేషన్ మరియు, అంతేకాకుండా, నాన్-ట్రివియల్ సూచనలను వ్రాయడం అవసరం ... మరొక తీవ్రమైన ప్రతికూలత ఏమిటంటే, ఈ విధానంతో అసెంబ్లీ సమయంలో ఏదైనా కాష్ చేయడానికి మార్గం లేదు.
ఇక్కడ వెర్ఫ్ యుటిలిటీ మన సహాయానికి వస్తుంది, అమలు చేస్తుంది స్మార్ట్ కాషింగ్ మరియు మీరు ఉపయోగించడానికి అనుమతిస్తుంది బాహ్య రిపోజిటరీలు. రిపోజిటరీ నుండి కోడ్ని జోడించడానికి werfని ఉపయోగించడం వలన నిర్మాణాన్ని గణనీయంగా వేగవంతం చేస్తుంది, ఎందుకంటే werf తప్పనిసరిగా రిపోజిటరీని ఒకసారి క్లోన్ చేసి ఆపై అమలు చేస్తుంది మాత్రమేfetch అవసరం ఐతే. అదనంగా, రిపోజిటరీ నుండి డేటాను జోడించేటప్పుడు, మేము అవసరమైన డైరెక్టరీలను మాత్రమే ఎంచుకోవచ్చు (మా విషయంలో ఇది డైరెక్టరీ docs), ఇది జోడించిన డేటా మొత్తాన్ని గణనీయంగా తగ్గిస్తుంది.
జెకిల్ అనేది స్టాటిక్ డేటాను కంపైల్ చేయడానికి రూపొందించబడిన ఒక సాధనం మరియు తుది చిత్రంలో అవసరం లేదు కాబట్టి, కంపైల్ చేయడం లాజికల్గా ఉంటుంది వెర్ఫ్ కళాఖండం, మరియు చివరి చిత్రంలోకి సంకలన ఫలితాన్ని మాత్రమే దిగుమతి చేయండి.
మేము werf.yaml అని వ్రాస్తాము
కాబట్టి, మేము ప్రతి వెర్షన్ను ప్రత్యేక వెర్ఫ్ ఆర్టిఫాక్ట్లో కంపైల్ చేయాలని నిర్ణయించుకున్నాము. అయితే మేము అసెంబ్లీ సమయంలో ఈ కళాఖండాలు ఎన్ని ఉంటాయో మాకు తెలియదు, కాబట్టి మేము స్థిర బిల్డ్ కాన్ఫిగరేషన్ను వ్రాయలేము (ఖచ్చితంగా చెప్పాలంటే, మేము ఇప్పటికీ చేయగలము, కానీ అది పూర్తిగా ప్రభావవంతంగా ఉండదు).
werf మీరు ఉపయోగించడానికి అనుమతిస్తుంది టెంప్లేట్లకు వెళ్లండి మీ కాన్ఫిగరేషన్ ఫైల్లో (werf.yaml), మరియు ఇది సాధ్యం చేస్తుంది ఫ్లైలో కాన్ఫిగరేషన్ను రూపొందించండి బాహ్య డేటాపై ఆధారపడి (మీకు కావలసినది!). మా విషయంలో బాహ్య డేటా సంస్కరణలు మరియు విడుదలల గురించిన సమాచారం, దీని ఆధారంగా మేము అవసరమైన కళాఖండాల సంఖ్యను సేకరిస్తాము మరియు ఫలితంగా మేము రెండు చిత్రాలను పొందుతాము: werf-doc и werf-dev వివిధ సర్క్యూట్లలో అమలు చేయడానికి.
బాహ్య డేటా పర్యావరణ వేరియబుల్స్ ద్వారా పంపబడుతుంది. వారి కూర్పు ఇక్కడ ఉంది:
RELEASES - ఫార్మాట్లో స్థలం-వేరు చేయబడిన విలువల జాబితా రూపంలో విడుదలల జాబితా మరియు సంబంధిత ప్రస్తుత వెర్షన్ వెర్ఫ్తో కూడిన లైన్ <НОМЕР_РЕЛИЗА>%<НОМЕР_ВЕРСИИ>. ఉదాహరణ: 1.0%v1.0.4-beta.20
CHANNELS - ఛానెల్ల జాబితా మరియు వెర్ఫ్ యొక్క సంబంధిత ప్రస్తుత వెర్షన్తో కూడిన లైన్, ఫార్మాట్లో స్థలం-వేరు చేయబడిన విలువల జాబితా రూపంలో <КАНАЛ>%<НОМЕР_ВЕРСИИ>. ఉదాహరణ: 1.0-beta%v1.0.4-beta.20 1.0-alpha%v1.0.5-alpha.22
ROOT_VERSION — werf విడుదల సంస్కరణ సైట్లో డిఫాల్ట్గా ప్రదర్శించబడుతుంది (అత్యధిక విడుదల సంఖ్య ద్వారా డాక్యుమెంటేషన్ను ప్రదర్శించడం ఎల్లప్పుడూ అవసరం లేదు). ఉదాహరణ: v1.0.4-beta.20
REVIEW_SHA — మీరు టెస్ట్ లూప్ కోసం సంస్కరణను రూపొందించాల్సిన రివ్యూ కమిట్ యొక్క హాష్.
ఈ వేరియబుల్స్ GitLab CI పైప్లైన్లో పూరించబడతాయి మరియు క్రింద ఎలా సరిగ్గా వ్రాయబడ్డాయి.
అన్నింటిలో మొదటిది, సౌలభ్యం కోసం, మేము నిర్వచించాము werf.yaml టెంప్లేట్ వేరియబుల్స్కి వెళ్లండి, వాటికి ఎన్విరాన్మెంట్ వేరియబుల్స్ నుండి విలువలను కేటాయించండి:
సైట్ యొక్క స్టాటిక్ వెర్షన్ను కంపైల్ చేయడానికి ఆర్టిఫ్యాక్ట్ యొక్క వివరణ సాధారణంగా మనకు అవసరమైన అన్ని సందర్భాల్లో ఒకే విధంగా ఉంటుంది (రూట్ వెర్షన్ను రూపొందించడంతో పాటు అలాగే dev సర్క్యూట్ కోసం వెర్షన్). కాబట్టి, మేము దానిని ఫంక్షన్ని ఉపయోగించి ప్రత్యేక బ్లాక్లోకి తరలిస్తాము define - తదుపరి ఉపయోగం కోసం include. మేము ఈ క్రింది వాదనలను టెంప్లేట్కు పంపుతాము:
Version — రూపొందించబడిన సంస్కరణ (ట్యాగ్ పేరు);
Channel - కళాకృతి రూపొందించబడిన నవీకరణ ఛానెల్ పేరు;
Commit — కమిట్ హాష్, ఆర్టిఫ్యాక్ట్ రివ్యూ కమిట్ కోసం రూపొందించబడితే;
కళాకృతి పేరు ప్రత్యేకంగా ఉండాలి. ఉదాహరణకు, ఛానెల్ పేరు (వేరియబుల్ విలువ) జోడించడం ద్వారా మనం దీనిని సాధించవచ్చు .Channel) కళాకృతి పేరుకు ప్రత్యయం వలె: artifact: doc-{{ .Channel }}. కానీ కళాఖండాల నుండి దిగుమతి చేసుకునేటప్పుడు, మీరు అదే పేర్లను సూచించవలసి ఉంటుందని మీరు అర్థం చేసుకోవాలి.
ఒక కళాఖండాన్ని వివరించేటప్పుడు, కింది వెర్ఫ్ ఫీచర్ ఉపయోగించబడుతుంది: మౌంటు. సేవా డైరెక్టరీని సూచించే మౌంటు build_dir పైప్లైన్ పరుగుల మధ్య జెకిల్ కాష్ను సేవ్ చేయడానికి మిమ్మల్ని అనుమతిస్తుంది గణనీయంగా పునర్వ్యవస్థీకరణను వేగవంతం చేస్తుంది.
మీరు ఫైల్ వినియోగాన్ని కూడా గమనించి ఉండవచ్చు releases.yml నుండి అభ్యర్థించబడిన విడుదల డేటాతో YAML ఫైల్ github.com (పైప్లైన్ను అమలు చేస్తున్నప్పుడు పొందిన కళాఖండం). సైట్ను కంపైల్ చేసేటప్పుడు ఇది అవసరం, కానీ వ్యాసం యొక్క సందర్భంలో ఇది మాకు ఆసక్తికరంగా ఉంటుంది ఎందుకంటే ఇది దాని స్థితిపై ఆధారపడి ఉంటుంది ఒకే ఒక కళాఖండాన్ని తిరిగి కలపడం — సైట్ యొక్క రూట్ వెర్షన్ యొక్క కళాఖండం (ఇతర కళాఖండాలలో ఇది అవసరం లేదు).
ఇది షరతులతో కూడిన ప్రకటనను ఉపయోగించి అమలు చేయబడుతుంది if టెంప్లేట్లు మరియు డిజైన్లను చూడండి {{ $Root.Files.Get "releases.yml" | sha256sum }} దశలో దశలు. ఇది క్రింది విధంగా పనిచేస్తుంది: రూట్ వెర్షన్ కోసం ఒక కళాఖండాన్ని నిర్మించేటప్పుడు (వేరియబుల్ .Channel సమానంగా root) ఫైల్ హాష్ releases.yml మొత్తం దశ సంతకాన్ని ప్రభావితం చేస్తుంది, ఎందుకంటే ఇది అన్సిబుల్ టాస్క్ (పారామితి) పేరులో భాగం name) అందువలన, మారుతున్నప్పుడు విషయము ఫైలు releases.yml సంబంధిత కళాఖండం మళ్లీ సమీకరించబడుతుంది.
దయచేసి బాహ్య రిపోజిటరీతో పని చేయడంపై కూడా శ్రద్ధ వహించండి. నుండి ఒక కళాఖండం యొక్క చిత్రంలో werf రిపోజిటరీ, డైరెక్టరీ మాత్రమే జోడించబడింది /docs, మరియు ఆమోదించబడిన పారామితులపై ఆధారపడి, అవసరమైన ట్యాగ్ లేదా రివ్యూ కమిట్ యొక్క డేటా వెంటనే జోడించబడుతుంది.
ఛానెల్లు మరియు విడుదలల యొక్క బదిలీ చేయబడిన సంస్కరణల యొక్క కళాకృతి యొక్క వివరణను రూపొందించడానికి కళాకృతి టెంప్లేట్ను ఉపయోగించడానికి, మేము వేరియబుల్పై లూప్ను నిర్వహిస్తాము .WerfVersions в werf.yaml:
{{ range .WerfVersions -}}
{{ $VersionsDict := splitn "%" 2 . -}}
{{ dict "Version" $VersionsDict._1 "Channel" $VersionsDict._0 "Root" $Root | include "doc_artifact" }}
---
{{ end -}}
ఎందుకంటే లూప్ అనేక కళాఖండాలను ఉత్పత్తి చేస్తుంది (మేము అలా ఆశిస్తున్నాము), వాటి మధ్య విభజనను పరిగణనలోకి తీసుకోవడం అవసరం - క్రమం --- (కాన్ఫిగరేషన్ ఫైల్ సింటాక్స్ గురించి మరింత సమాచారం కోసం, చూడండి డాక్యుమెంటేషన్) ముందుగా నిర్వచించినట్లుగా, లూప్లో టెంప్లేట్ని కాల్ చేస్తున్నప్పుడు, మేము వెర్షన్ పారామితులు, URL మరియు రూట్ సందర్భాన్ని పాస్ చేస్తాము.
అదేవిధంగా, కానీ లూప్ లేకుండా, మేము ఆర్టిఫ్యాక్ట్ టెంప్లేట్ని “ప్రత్యేక సందర్భాలు” అని పిలుస్తాము: రూట్ వెర్షన్ కోసం, అలాగే రివ్యూ కమిట్ నుండి వచ్చిన వెర్షన్:
{{ dict "Version" .WerfRootVersion "Channel" "root" "Root" $Root | include "doc_artifact" }}
---
{{- if .WerfReviewCommit }}
{{ dict "Version" "review" "Channel" "review" "Commit" .WerfReviewCommit "Root" $Root | include "doc_artifact" }}
{{- end }}
వేరియబుల్ సెట్ చేయబడితే మాత్రమే సమీక్ష కమిట్ కోసం ఆర్టిఫ్యాక్ట్ నిర్మించబడుతుందని దయచేసి గమనించండి .WerfReviewCommit.
కళాఖండాలు సిద్ధంగా ఉన్నాయి - ఇది దిగుమతి ప్రారంభించడానికి సమయం!
చివరి చిత్రం, కుబెర్నెటీస్లో అమలు చేయడానికి రూపొందించబడింది, సర్వర్ కాన్ఫిగరేషన్ ఫైల్ జోడించబడిన సాధారణ NGINX nginx.conf మరియు కళాఖండాల నుండి స్థిరంగా ఉంటుంది. సైట్ యొక్క రూట్ వెర్షన్ యొక్క కళాఖండానికి అదనంగా, మేము వేరియబుల్లో లూప్ను పునరావృతం చేయాలి .WerfVersions ఛానెల్ యొక్క కళాఖండాలను దిగుమతి చేయడానికి మరియు సంస్కరణలను విడుదల చేయడానికి + మేము ఇంతకు ముందు అనుసరించిన కళాకృతుల నామకరణ నియమాన్ని అనుసరించండి. ప్రతి కళాకృతి రెండు భాషల కోసం సైట్ యొక్క సంస్కరణలను నిల్వ చేస్తుంది కాబట్టి, మేము వాటిని కాన్ఫిగరేషన్ అందించిన ప్రదేశాలకు దిగుమతి చేస్తాము.
ప్రధాన చిత్రంతో పాటుగా dev సర్క్యూట్లో ప్రారంభించబడిన అదనపు చిత్రం, సైట్ యొక్క రెండు వెర్షన్లను మాత్రమే కలిగి ఉంది: సమీక్ష కమిట్ నుండి వచ్చిన సంస్కరణ మరియు సైట్ యొక్క రూట్ వెర్షన్ (సాధారణ ఆస్తులు ఉన్నాయి మరియు మీకు గుర్తు ఉంటే , విడుదల డేటా). అందువల్ల, అదనపు చిత్రం దిగుమతి విభాగంలో మాత్రమే ప్రధానమైనది నుండి భిన్నంగా ఉంటుంది (మరియు, వాస్తవానికి, పేరులో):
image: werf-dev
...
import:
- artifact: doc-root
add: /app/_main_site
to: /app/main_site
before: setup
- artifact: doc-root
add: /app/_ru_site
to: /app/ru_site
before: setup
{{- if .WerfReviewCommit }}
- artifact: doc-review
add: /app/_main_site
to: /app/main_site/review
before: setup
- artifact: doc-review
add: /app/_ru_site
to: /app/ru_site/review
before: setup
{{- end }}
పైన పేర్కొన్నట్లుగా, సెట్ ఎన్విరాన్మెంట్ వేరియబుల్ అమలు చేయబడినప్పుడు మాత్రమే సమీక్ష కమిట్ కోసం ఆర్టిఫ్యాక్ట్ రూపొందించబడుతుంది REVIEW_SHA. ఎన్విరాన్మెంట్ వేరియబుల్ లేకుంటే werf-dev ఇమేజ్ని రూపొందించకుండా ఉండటం సాధ్యమవుతుంది REVIEW_SHA, కానీ క్రమంలో విధానాల ద్వారా శుభ్రపరచడం werfలోని డాకర్ చిత్రాలు werf-dev చిత్రం కోసం పనిచేశాయి, పైప్లైన్ నిర్మాణాన్ని సులభతరం చేయడానికి మేము దానిని రూట్ వెర్షన్ ఆర్టిఫాక్ట్తో మాత్రమే నిర్మించడానికి వదిలివేస్తాము (ఇది ఇప్పటికే ఏమైనప్పటికీ నిర్మించబడింది).
అసెంబ్లీ సిద్ధంగా ఉంది! CI/CD మరియు ముఖ్యమైన సూక్ష్మ నైపుణ్యాలకు వెళ్దాం.
GitLab CIలో పైప్లైన్ మరియు డైనమిక్ బిల్డ్ యొక్క లక్షణాలు
బిల్డ్ను రన్ చేస్తున్నప్పుడు మనం ఉపయోగించిన ఎన్విరాన్మెంట్ వేరియబుల్స్ను సెట్ చేయాలి werf.yaml. ఇది REVIEW_SHA వేరియబుల్కి వర్తించదు, GitHub హుక్ నుండి పైప్లైన్కి కాల్ చేస్తున్నప్పుడు మేము సెట్ చేస్తాము.
మేము బాష్ స్క్రిప్ట్లో అవసరమైన బాహ్య డేటాను రూపొందిస్తాము generate_artifacts, ఇది రెండు GitLab పైప్లైన్ కళాఖండాలను ఉత్పత్తి చేస్తుంది:
файл releases.yml విడుదల డేటాతో,
файл common_envs.sh, ఎగుమతి చేయవలసిన పర్యావరణ చరరాశులను కలిగి ఉంటుంది.
ఫైల్ కంటెంట్లు generate_artifacts మీరు మాలో కనుగొంటారు ఉదాహరణలతో రిపోజిటరీలు. డేటాను స్వీకరించడం అనేది వ్యాసం యొక్క అంశం కాదు, కానీ ఫైల్ common_envs.sh మాకు ముఖ్యం, ఎందుకంటే వెర్ఫ్ యొక్క పని దానిపై ఆధారపడి ఉంటుంది. దాని కంటెంట్ యొక్క ఉదాహరణ:
మీరు అటువంటి స్క్రిప్ట్ యొక్క అవుట్పుట్ని ఉపయోగించవచ్చు, ఉదాహరణకు, బాష్ ఫంక్షన్ని ఉపయోగించి source.
ఇప్పుడు సరదా భాగం వస్తుంది. అప్లికేషన్ యొక్క బిల్డ్ మరియు డిప్లాయ్మెంట్ రెండూ సరిగ్గా పని చేయడానికి, దాన్ని నిర్ధారించడం అవసరం werf.yaml ఇది అదే కనీసం ఒక పైప్లైన్ లోపల. ఈ షరతు నెరవేరకపోతే, అసెంబ్లీ సమయంలో వెర్ఫ్ లెక్కించే దశల సంతకాలు మరియు ఉదాహరణకు, విస్తరణ భిన్నంగా ఉంటాయి. ఇది విస్తరణ లోపానికి దారి తీస్తుంది, ఎందుకంటే... విస్తరణకు అవసరమైన చిత్రం లేదు.
మరో మాటలో చెప్పాలంటే, సైట్ ఇమేజ్ అసెంబ్లీ సమయంలో విడుదలలు మరియు సంస్కరణల గురించిన సమాచారం ఒకేలా ఉంటే మరియు విస్తరణ సమయంలో కొత్త వెర్షన్ విడుదల చేయబడి, పర్యావరణ వేరియబుల్స్ వేర్వేరు విలువలను కలిగి ఉంటే, అప్పుడు విస్తరణ లోపంతో విఫలమవుతుంది: అన్ని తరువాత, కొత్త వెర్షన్ యొక్క కళాఖండం ఇంకా నిర్మించబడలేదు.
తరం ఉంటే werf.yaml బాహ్య డేటాపై ఆధారపడి ఉంటుంది (ఉదాహరణకు, ప్రస్తుత సంస్కరణల జాబితా, మా విషయంలో వలె), అప్పుడు అటువంటి డేటా యొక్క కూర్పు మరియు విలువలు పైప్లైన్లో నమోదు చేయబడాలి. బాహ్య పారామితులు చాలా తరచుగా మారితే ఇది చాలా ముఖ్యం.
మేము చేస్తాము బాహ్య డేటాను స్వీకరించండి మరియు రికార్డ్ చేయండి GitLab లో పైప్లైన్ మొదటి దశలో (ప్రీబిల్డ్) మరియు వాటిని మరింత రూపంలో ప్రసారం చేయండి GitLab CI కళాకృతి. ఇదే కాన్ఫిగరేషన్తో పైప్లైన్ జాబ్లను (బిల్డ్, డిప్లాయ్, క్లీనప్) అమలు చేయడానికి మరియు పునఃప్రారంభించడానికి ఇది మిమ్మల్ని అనుమతిస్తుంది werf.yaml.
వేదిక యొక్క విషయాలు ప్రీబిల్డ్ ఫైలు .gitlab-ci.yml:
కళాకృతిలో బాహ్య డేటాను సంగ్రహించిన తర్వాత, మీరు ప్రామాణిక GitLab CI పైప్లైన్ దశలను ఉపయోగించి నిర్మించవచ్చు మరియు అమలు చేయవచ్చు: బిల్డ్ మరియు డిప్లాయ్. మేము GitHub werf రిపోజిటరీ (అంటే, GitHubలో రిపోజిటరీలో మార్పులు వచ్చినప్పుడు) నుండి hookలను ఉపయోగించి పైప్లైన్ను ప్రారంభించాము. విభాగంలోని GitLab ప్రాజెక్ట్ లక్షణాలలో వాటి కోసం డేటాను కనుగొనవచ్చు CI/CD సెట్టింగ్లు -> పైప్లైన్ ట్రిగ్గర్లు, ఆపై GitHubలో సంబంధిత Webhookని సృష్టించండి (సెట్టింగ్లు -> వెబ్హుక్స్).
GitLab వేదిక నుండి నిర్మాణ దశకు రెండు కళాఖండాలను జోడిస్తుంది ప్రీబిల్డ్, కాబట్టి మేము నిర్మాణాన్ని ఉపయోగించి సిద్ధం చేసిన ఇన్పుట్ డేటాతో వేరియబుల్లను ఎగుమతి చేస్తాము source common_envs.sh. మేము షెడ్యూల్ ప్రకారం పైప్లైన్ను ప్రారంభించడం మినహా అన్ని సందర్భాల్లో నిర్మాణ దశను ప్రారంభిస్తాము. షెడ్యూల్ ప్రకారం, మేము శుభ్రపరచడం కోసం పైప్లైన్ను అమలు చేస్తాము - ఈ సందర్భంలో అసెంబ్లీని నిర్వహించాల్సిన అవసరం లేదు.
విస్తరణ దశలో, YAML టెంప్లేట్ని ఉపయోగించి, ఉత్పత్తి మరియు దేవ్ సర్క్యూట్లకు విస్తరణ కోసం విడిగా రెండు పనులను వివరిస్తాము:
వెర్ఫ్ విస్తరణను నిర్వహించాల్సిన క్లస్టర్ సందర్భాన్ని సూచించడంలో మాత్రమే టాస్క్లు వేర్వేరుగా ఉంటాయి (WERF_KUBE_CONTEXT), మరియు లూప్ ఎన్విరాన్మెంట్ వేరియబుల్స్ సెట్ చేయడం (environment.name и environment.url), తరువాత హెల్మ్ చార్ట్ టెంప్లేట్లలో ఉపయోగించబడతాయి. మేము టెంప్లేట్ల కంటెంట్లను అందించము, ఎందుకంటే... సందేహాస్పద అంశం కోసం ఆసక్తికరమైన ఏమీ లేదు, కానీ మీరు వాటిని కనుగొనవచ్చు వ్యాసం కోసం రిపోజిటరీలు.
చివరి టచ్
వెర్ఫ్ సంస్కరణలు చాలా తరచుగా విడుదలవుతాయి కాబట్టి, కొత్త చిత్రాలు తరచుగా నిర్మించబడతాయి మరియు డాకర్ రిజిస్ట్రీ నిరంతరం అభివృద్ధి చెందుతుంది. అందువల్ల, విధానాల ఆధారంగా ఆటోమేటిక్ ఇమేజ్ క్లీనప్ను కాన్ఫిగర్ చేయడం అత్యవసరం. ఇది చేయడం చాలా సులభం.
అమలు చేయడానికి మీకు ఇది అవసరం:
దీనికి శుభ్రపరిచే దశను జోడించండి .gitlab-ci.yml;
శుభ్రపరిచే పని యొక్క కాలానుగుణ అమలును జోడించండి;
రైట్ యాక్సెస్ టోకెన్తో ఎన్విరాన్మెంట్ వేరియబుల్ని సెటప్ చేయండి.
దీనికి శుభ్రపరిచే దశను జోడిస్తోంది .gitlab-ci.yml:
మేము ఇప్పటికే వీటన్నింటిని కొంచెం ఎక్కువగా చూశాము - దీన్ని శుభ్రం చేయడానికి మాత్రమే మీరు మొదట డాకర్ రిజిస్ట్రీలోని చిత్రాలను తొలగించే హక్కును కలిగి ఉన్న టోకెన్తో డాకర్ రిజిస్ట్రీకి లాగిన్ చేయాలి (స్వయంచాలకంగా జారీ చేయబడిన GitLab CI టాస్క్ టోకెన్ చేయదు. అటువంటి హక్కులు ఉన్నాయి). టోకెన్ తప్పనిసరిగా GitLabలో ముందుగానే సృష్టించబడాలి మరియు దాని విలువ తప్పనిసరిగా పర్యావరణ వేరియబుల్లో పేర్కొనబడాలి WERF_IMAGES_CLEANUP_PASSWORD ప్రాజెక్ట్ (CI/CD సెట్టింగ్లు -> వేరియబుల్స్).
అవసరమైన షెడ్యూల్తో శుభ్రపరిచే పనిని జోడించడం పూర్తయింది CI/CD ->
సర్వీసు షెడ్యూల్స్.
అంతే: డాకర్ రిజిస్ట్రీలోని ప్రాజెక్ట్ ఉపయోగించని చిత్రాల నుండి నిరంతరం పెరగదు.
ఆచరణాత్మక భాగం ముగింపులో, వ్యాసం నుండి పూర్తి జాబితాలు అందుబాటులో ఉన్నాయని నేను మీకు గుర్తు చేస్తాను Git:
మేము లాజికల్ అసెంబ్లీ నిర్మాణాన్ని అందుకున్నాము: ప్రతి సంస్కరణకు ఒక కళాఖండం.
అసెంబ్లీ సార్వత్రికమైనది మరియు వెర్ఫ్ యొక్క కొత్త సంస్కరణలు విడుదలైనప్పుడు మాన్యువల్ మార్పులు అవసరం లేదు: వెబ్సైట్లోని డాక్యుమెంటేషన్ స్వయంచాలకంగా నవీకరించబడుతుంది.
వేర్వేరు ఆకృతుల కోసం రెండు చిత్రాలు సమావేశమయ్యాయి.
ఇది త్వరగా పని చేస్తుంది, ఎందుకంటే కాషింగ్ సాధ్యమైనంత ఎక్కువగా ఉపయోగించబడుతుంది - werf యొక్క కొత్త వెర్షన్ విడుదల చేయబడినప్పుడు లేదా GitHub హుక్ రివ్యూ కమిట్ కోసం పిలిచినప్పుడు, మార్చబడిన సంస్కరణతో సంబంధిత కళాకృతి మాత్రమే పునర్నిర్మించబడుతుంది.
ఉపయోగించని చిత్రాలను తొలగించడం గురించి ఆలోచించాల్సిన అవసరం లేదు: వెర్ఫ్ విధానాల ప్రకారం శుభ్రపరచడం డాకర్ రిజిస్ట్రీని క్రమంలో ఉంచుతుంది.
కనుగొన్న
werfని ఉపయోగించడం వలన అసెంబ్లీ కూడా కాషింగ్ మరియు బాహ్య రిపోజిటరీలతో పని చేస్తున్నప్పుడు కాషింగ్ కారణంగా అసెంబ్లీ త్వరగా పని చేస్తుంది.
బాహ్య Git రిపోజిటరీలతో పని చేయడం వలన ప్రతిసారీ మొత్తం రిపోజిటరీని క్లోన్ చేయడం లేదా గమ్మత్తైన ఆప్టిమైజేషన్ లాజిక్తో చక్రాన్ని తిరిగి ఆవిష్కరించడం అవసరం లేదు. werf కాష్ని ఉపయోగిస్తుంది మరియు క్లోనింగ్ను ఒక్కసారి మాత్రమే చేస్తుంది, ఆపై ఉపయోగిస్తుంది fetch మరియు అవసరమైనప్పుడు మాత్రమే.
బిల్డ్ కాన్ఫిగరేషన్ ఫైల్లో గో టెంప్లేట్లను ఉపయోగించగల సామర్థ్యం werf.yaml బాహ్య డేటాపై ఆధారపడి ఉండే అసెంబ్లీని వివరించడానికి మిమ్మల్ని అనుమతిస్తుంది.
వెర్ఫ్లో మౌంట్ ఉపయోగించడం కళాఖండాల సేకరణను గణనీయంగా వేగవంతం చేస్తుంది - కాష్ కారణంగా, ఇది అన్ని పైప్లైన్లకు సాధారణం.
werf క్లీనప్ని కాన్ఫిగర్ చేయడాన్ని సులభతరం చేస్తుంది, ఇది డైనమిక్గా నిర్మించేటప్పుడు చాలా ముఖ్యమైనది.