abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 14:33 | Humor

    Copilot automaticky vkládal do pull requestů 'propagační tipy', reklamní text se na GitHubu objevil ve více než jedenácti tisících pull requestech. Po vlně kritiky byla tato funkce zablokována a produktový manažer Tim Rogers připustil, že umožnit Copilotovi upravovat cizí pull requesty bez vědomí autorů byla chyba.

    NUKE GAZA! 🎆 | Komentářů: 1
    dnes 12:55 | Upozornění

    Je 31. března a tedy Světový den zálohování (World Backup Day). Co by se stalo, kdyby Vám právě teď odešel počítač, tablet nebo telefon, který používáte?

    Ladislav Hagara | Komentářů: 0
    dnes 12:44 | Upozornění

    Digitální a informační agentura (DIA) přistupuje ke změně formátu důvěryhodného seznamu České republiky z verze TLv5 na verzi TLv6, která nastane 29. dubna 2026 v 00:00 (CET). Ke změně formátu důvěryhodných seznamů členských států (tzv. Trusted Lists) dochází na základě změn příslušné unijní legislativy. Důvěryhodné seznamy se používají v rámci informačních systémů a aplikací zejména pro účely ověřování platnosti elektronických

    … více »
    Ladislav Hagara | Komentářů: 1
    dnes 05:00 | Nová verze

    Rspamd (Wikipedie), tj. open source systému pro filtrování nevyžádané pošty, byl vydán v nové major verzi 4.0.0. Přehled novinek v Changelogu.

    Ladislav Hagara | Komentářů: 1
    včera 23:11 | Nová verze

    SolveSpace (Wikipedie), tj. multiplatformní open source parametrický 2D/3D CAD, byl vydán v nové verzi 3.2. Přehled novinek v Changelogu na GitHubu. Vyzkoušet lze novou oficiální webovou verzi.

    Ladislav Hagara | Komentářů: 6
    včera 18:22 | Pozvánky

    Organizátoři Dne IPv6, tradiční akce věnované tématům spojeným s tímto protokolem, vyhlásili Call for Abstracts. Na webu konference mohou zájemci přihlašovat příspěvky o délce 20 nebo 40 minut či 10minutové lighting talky a to až do 30. dubna. Tvůrci programu uvítají návrhy přednášek z akademického i komerčního sektoru, které mohou být technického i netechnického zaměření. Den IPv6 se letos uskuteční 4. června a místem konání bude i

    … více »
    VSladek | Komentářů: 5
    včera 15:00 | Zajímavý software

    Euro-Office (Wikipedie) je evropský fork open source kancelářského balíku OnlyOffice. Za forkem stojí koalice firem IONOS, Nextcloud, Eurostack, XWiki, OpenProject, Soverin, Abilian a BTactic. Cílem je zajistit digitální suverenitu Evropy a snížit závislost na neevropských platformách. Projekt vznikl mimo jiné v reakci na nedávné uzavření cloudové služby OnlyOffice. OnlyOffice obviňuje Euro-Office z porušení licenčních podmínek. Na možné problémy upozorňuje i Collabora Online. Jednostranná změna licence není v pořádku.

    Ladislav Hagara | Komentářů: 25
    včera 05:11 | Komunita

    Byly zpracovány a na YouTube zveřejněny videozáznamy jednotlivých přednášek z letošního Installfestu.

    Ladislav Hagara | Komentářů: 1
    včera 00:22 | Komunita

    Během akce Arduino Days 2026 byl publikován Arduino Open Source Report 2025 (pdf) a oznámeno 7 nových produktů kompatibilních s deskou UNO Q (Arduino USB-C Power Supply, USB-C Cable, USB-C Hub, UNO Media Carrier, UNO Breakout Carrier, Bug Hopper, Modulino LED Matrix).

    Ladislav Hagara | Komentářů: 2
    29.3. 20:22 | IT novinky

    Google v pátek spustil v Česku Vyhledávání Live. Tato novinka umožňuje lidem vést plynulou konverzaci s vyhledávačem v češtině. A to prostřednictvím hlasu, nebo prostřednictvím toho, na co ukážou svým fotoaparátem či kamerou v mobilu. Rozšíření této multimodální funkce je možné díky nasazení Gemini 3.1 Flash Live, nového hlasového a audio modelu, který je od základu vícejazyčný, takže umožňuje lidem po celém světě mluvit na vyhledávač přirozeně a v jazyce, který je jim nejbližší.

    Ladislav Hagara | Komentářů: 1
    Které desktopové prostředí na Linuxu používáte?
     (15%)
     (7%)
     (1%)
     (12%)
     (30%)
     (3%)
     (5%)
     (2%)
     (14%)
     (24%)
    Celkem 1192 hlasů
     Komentářů: 29, poslední dnes 11:17
    Rozcestník

    Git, bad practice a jak z toho ven - brainstorming

    11.3.2012 21:25 | Přečteno: 1548× | SW

    Zákazník požaduje vývoj na svém ostrém serveru, já mám kopii přez GIT repozitáře, ale rád bych změnil výrazně strukturu u sebe, abych mohl vše instalovat jako balíčky distribuce. Ale zároveň potřebuju backportovat změny z ostrého serveru. Jak se toho nejlíp zhostit?

    Dostal jsem se do mírně delikátní situace u jednoho zákazníka a přemýšlím jak z ní nejlíp ven. Vztahy máme dlouhodobě výborné, spokojenost na obou stranách a tak dál a tak dál.

    Ale některé jeho požadavky mi dělají trochu starosti. Spravuju a vyvýjím mu systém na míru, z části postavený i na webových stránkách (a z větší části na nich vlastně nezávislý, ale tato část je v pohodě.) Ten systém jsem kdysi zdědil, posléze přepsal od základů do příčetnější podoby a dlouhodobě ho rozvíjím a udržuju. Za ta léta se už dá vypozorovat cyklus, kdy dlouhou dobu všechno je v pohodě, vlastně nic nechtějí a já si můžu dělat co chci (čili chystat nové featury). Pak se najednou všechno zblázní a předělává se webové rozhraní stylem "před hodinou bylo pozdě", jednou rukou telefonuju, druhou přepisuju a uchem slyším, jak oni komentujou změny. Pak se prach usadí a zase delší dobu klid. Takhle prostě fungujou a to se nezmění.

    Ano - vyvýjet na ostrém serveru je Bad Practice jako vyšitá, ale klient to požaduje kvůli rychlosti odezvy a platí dobře, takže náš zákazník, náš pán. Co si okolo toho udělám v zákulisí ho netrápí, v tom mám volnou ruku.

    Z historických důvodů je v systému několik různých způsobů, jak nasazovat nové věci - od relativně jednoduchých konzervativních, kdy si vše připravím a pak skriptem nahrávám otestované balíky do příslušných adresářů, až po klasický nouzový, kdy exponovanou webovou část mám uloženou v GITu na ostrých serverech (mají jich víc, polonezávislých), synchronizuju přez svůj centrální gitserver a na NB kde obvykle pracuju.

    Zatím to chodilo celkem dobře, když se zjančili, tak jsem vše ohackoval na serveru, poté syncnul a rozdistribuoval, následně doladit speciality jednotlivých serverů. Tato část měla hlavní repozitář jako přímou kopii struktury na serveru, časem se na ni nabalila řada skriptů, přílepků, dodatků a jiných nesouvisejících věcí a teď nastal okamžik, kdy už to přestává být únosné.

    Takže jsem opásal bedra svá a jal se opět kydat Augiášův chlív. Polovinu věcí jsem rozházel do desítek balíčků, každý ve vlastním repozitáři, vytvořil si svůj PORTAGEOVERLAY, kam to sypu a odkud to instaluju jako všechny systémové záležitosti. Zatím to funguje skvěle a věci složité se najednou stávají opět přehlednými - rozhodně je lepší instalovat novou verzi stylem "emerge --update @world" a nechat na distribuci, ať si sama zjistí, co potřebuje, kam to patří a co je třeba vyčistit, než na to všechno psát nějaké ad-hoc skripty.

    Problém je s tím webovým rozhraním - logicky se rozpadá na několik balíčků, ale zatím žije v jednom repozitáři. A je potřeba zajistit zpětnou propagaci nasekaných změn ze serveru zpět do mého (nyní již vyčištěného a přeorganizovaného) vývojového prostředí.

    Takže přemýšlím, jak si věci zorganizovat v zákulisí, abych s tím měl v dlouhodobém výhledu co nejmíň práce.
    server1 \
    server2  +--- gitserver --- NB
    server3 /
    
    server* -- WWW.git

    NB -- WWW.git, balik1.git, balik2.git, balik3.git .....

    přičemž WWW.git obsahuje zhruba tytéž soubory jako souhrn všech balíků, ale v docela jiném uspořádání, co se týče adresářů (z historických důvodů a protože na serveru je to takhle nahňácané dohromady)

    Požadovaný workflow:

    WWW.git (server) --> WWW.git (NB) --> magie --> balik*.git --> balik*.ebuild --> sync NB..server --> emerge world --> přepsání souborů ve WWW.git

    V podstatě bych potřeboval, abych byl schopný nějakým (polo)automatickým způsobem vzít na NB z WWW.git repozitáře soubory i s historií změn od poslední synchronizace a rozhodit je do příslušných balik*.git, s tím, že se tam přenesou i ty commit hlášky.

    A po reinstalaci balíčků na server nějak podchytit nainstalované změny (teoreticky by to měl vychytat WWW.git(server), že by mu vyšlo, že ačkoliv jsou soubory přepsané, tak je obsah stejný, takže vše OK, nebo že se cosi pozměnilo a umožnit mi to dořešit, zda jde o nový vývoj z NB, nebo zda to přepisuju zastaralou verzí, která nějak unikla aktualizaci.)

    Git mám celkem už ochočený, ale na to jak vymyslet tuhle vychytávku jsem ještě nepřišel. (Zatím mi vychází nějaké dost složité přehrávání histori pomocí bashových skriptů a strašná spousta skriptů definujících, co kam překopírovat. Ale pořád se mi zdá, že to musí jít udělat nějak jednodušeji)        

    Hodnocení: 100 %

            špatnédobré        

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    Komentáře

    Vložit další komentář

    Josef Kufner avatar 11.3.2012 23:15 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Git, bad practice a jak z toho ven - brainstorming
    Kdyby to bylo čistě jen v Gitu, tak bych si držel jeden hlavní repositář a servery z něj updatoval automaticky, ale s manuálním spouštěním (aby se to nerozbilo samo). Hezky si to tagoval (git describe je fajn) a případně větvil. V nějakém konfiguráku bych mohl mít, který server má mít jakou větev/tag nainstalovanou a synclo by se to po pushnutí změn do toho hlavního repositáře.

    No a když by byly na nějakém serveru lokální změny (pár commitů), tak by se udělal git pull --rebase, čímž by změny zůstaly na povrchu historie a bylo by snadné je přetáhnout (git cherry-pick) do hlavního repositáře.
    Hello world ! Segmentation fault (core dumped)
    Gilhad avatar 12.3.2012 01:24 Gilhad | skóre: 20 | blog: gilhadoviny
    Rozbalit Rozbalit vše Re: Git, bad practice a jak z toho ven - brainstorming
    Tak jsem premyslel jak bych popsal co nejlepe co si myslim, ze by mi mohlo pomoct:

    Normalne mam projekt na notebooku ktery ma branch master a jeho origin/master je na jinem serveru. prikazy push/fetch synchronizuji origin/master na NB s tim na serveru. git merge origin/master mi pretahne zmeny do mojeho projektu.

    Co by se mi libilo by bylo mit takhle dva (ci vice) projektu, kazdy by mel svuj origin/master na nejakem serveru, ale jeste navic by mely dva adresare mezi sebou navazany obdobny vztah
    Projekt_jedna
    +--A
    +--B (svazan s Projekt_dva--B)
    +--C
    
    Projekt_dva
    +--D
    +--E
    +--B ("origin" pro Projekt_jedna--B)
    +--F
    
    takze bych mohl udelat
    cd Projekt_jedna/B
    git fetch Projekt_dva/B
    git merge Projekt_dva/B
    git push Projekt_dva/B
    
    a ten fetch/merge/push by se tykal jen toho podstromu B a jeho protejsku B v druhem projektu.

    Myslim, ze jsem nekde zahledl cosi o sub-projektech, ale tehdy to nepochopil a nepotreboval - zkusim si to precist znovu, treba to nekam vede
    Gilhad avatar 12.3.2012 01:46 Gilhad | skóre: 20 | blog: gilhadoviny
    Rozbalit Rozbalit vše Re: Git, bad practice a jak z toho ven - brainstorming
    Tesne vedle :) Neco zajimaveho je o kapitolu dal (a dost s tim souvisi)

    http://progit.org/book/ch6-7.html

    necham si projit hlavou, jestli a jak by to slo zkombinovat
    Josef Kufner avatar 12.3.2012 10:48 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Git, bad practice a jak z toho ven - brainstorming
    Git submodule. B dej do samostatného repositáře a v ostatních ho přidáš jako submodul. Na serveru pak uděláš namísto git pull trošku složitější operaci: git pull && git submodule update.
    Hello world ! Segmentation fault (core dumped)
    12.3.2012 10:34 Bubu
    Rozbalit Rozbalit vše Re: Git, bad practice a jak z toho ven - brainstorming
    Vy pouzivate Gentoo na produkcnim serveru? WTF?
    12.3.2012 11:57 SPM | skóre: 28
    Rozbalit Rozbalit vše Re: Git, bad practice a jak z toho ven - brainstorming
    No a? Já ho na svých serverech mám taky a nemám s ním žádný problém.
    Gilhad avatar 12.3.2012 14:59 Gilhad | skóre: 20 | blog: gilhadoviny
    Rozbalit Rozbalit vše Re: Git, bad practice a jak z toho ven - brainstorming
    Ano, co je s tim za problem? Nikde prece neni psano, ze musim updatovat denne. U stabilni verze muzu vydrzet tak dlouho, dokud nepotrebuju novou vlastnost, nebo odstranit kritickou zranitelnost. Plus mi jako distribuce sedi nejlip.

    Založit nové vláknoNahoru

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.