-
Data: 2011-09-17 15:02:03
Temat: Re: Modułowość programu - założenia
Od: Michoo <m...@v...pl> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]W dniu 16.09.2011 22:28, Maciej Sobczak pisze:
> On Sep 16, 11:33 am, Michoo<m...@v...pl> wrote:
>
>>> To podej cie ma sens tylko wtedy, gdy b dzie istnia mniej lub
>>> bardziej otwarty rynek plugin w, czyli gdy u ytkownicy b d mogli
>>> pozyska pluginy niezale nie od Ciebie.
>>
>> Z tym si nie zgodz .
>> Ma to sen tak e wtedy, gdy r ni u ytkownicy b d u ywa r nych
>> podzbior w funkcjonalno ci dostarczanej przez jednego dostawc . Nie
>> trzeba wtedy dla ka dego z 50 klient w linkowa osobnej wersji
>> aplikacji, tylko wys a im odpowiedni zestaw plugin w (a nawet sami mog
>> sobie taki zestaw wyklika ).
>
> No właśnie - mogą sobie wyklikać. Tak, jak się klika
> konfigurację jądra dla Linuksa albo FreeBSD. Coś jak zamawianie pizzy
> - wybierasz składniki a pizzaiolo przy piekarniku lepi wszystko tak
> jak sobie wybrałeś. Nie widzę tu problemu z linkowaniem statycznym.
Ja też nie widzę specjalnego problemu - albo pakujemy wybrane pliki .so,
albo gcc na wybranych plikach .a.
>
> Praktykuje się również inne podejście - wszystko zlinkować co się da i
> dostarczyć klientowi cały produkt, ale tylko niektóre jego moduły są
> aktywne, reszta jest nieaktywna i aktywuje się ją później.
Tylko co w sytuacji gdy nie da się tego zlinkować bo mamy plugin X i
jego wersję dla firm A,B różniące się kilkoma szczegółami, których
wprowadzenie do mainline nie jest ani celowe ani korzystne?
> Wadą jest
> to, że się bierze większy pakiet na początku ale zaletą jest to, że
> późniejsza aktywacja modułów w ogóle nie musi nawet wymagać połączenia
> przez net. I to się praktykuje, nawet często.
Ale też aktualizacja wymaga konstruowania binarnych łat albo pobierania
całości na nowo, nie można wysłać po prostu zmodyfikowanej jednej
biblioteki. A z drugiej strony nie ma problemu - możemy klientowi
dostarczyć na wstępie cały zestaw pluginów a potem aktywować je za
pomocą kluczy.
> Oczywiście chętnie usłyszę jakiś przykładowy kontrargument, tylko
> praktyczny.
Załóżmy, że mamy aplikację obsługującą kilkaset żądań na minutę. W
przypadku odpowiednio rozwiązanego systemu pluginów możemy oznaczyć
plugin jako przeznaczony do wyładowania(zostanie wyładowany gdy skończą
się wszystkie połączenia), załadować nową wersję i mieć aktualizację bez
downtime.
>
> Natomiast jednego jestem pewny: jeżeli pozwolisz użytkownikom
> swobodnie ładować pluginy,
Tu nie chodzi o swobodne ładowanie a o wygodne z punktu widzenia
programisty zarządzanie podzbiorami funkcjonalności.
Można by powiedzieć, że kolejny krok w kierunku lepszej enkapsulacji.
Przykład:
w pewnej, rzadkiej sytuacji moduł A używał foo z modułu B, foo zostaje
zmodyfikowana (działa teraz w sposób niekompatybilny) i dopiero na
etapie szczegółowych testów (albo dopiero w praniu) wychodzi zależność
A->B. Gdyby to były pluginy to komunikowały by się po swoich publicznych
interfejsach i byłoby wiadomo od początku, że specyfikacja foo jest jego
składową.
--
Pozdrawiam
Michoo
Następne wpisy z tego wątku
- 17.09.11 21:40 Maciej Sobczak
- 18.09.11 07:42 Jacek Czerwinski
- 18.09.11 08:12 Artur Muszyński
- 18.09.11 08:32 Jacek Czerwinski
- 18.09.11 08:59 Patryk Włos
- 18.09.11 09:31 Robert Winkler
- 18.09.11 12:49 Paweł Kierski
- 18.09.11 13:31 Jacek Czerwinski
- 18.09.11 15:55 A.L.
- 18.09.11 16:21 Waldek M.
- 18.09.11 16:59 Lukasz
- 18.09.11 21:35 R. P.
- 20.09.11 22:30 Edek
- 20.09.11 23:30 A.L.
Najnowsze wątki z tej grupy
- Can you activate BMW 48V 10Ah Li-Ion battery, connecting to CAN-USB laptop interface ?
- We Wrocławiu ruszyła Odra 5, pierwszy w Polsce komputer kwantowy z nadprzewodzącymi kubitami
- Ada-Europe - AEiC 2025 early registration deadline imminent
- John Carmack twierdzi, że gdyby gry były optymalizowane, to wystarczyły by stare kompy
- Ada-Europe Int.Conf. Reliable Software Technologies, AEiC 2025
- Linuks od wer. 6.15 przestanie wspierać procesory 486 i będzie wymagać min. Pentium
- ,,Polski przemysł jest w stanie agonalnym" - podkreślił dobitnie, wskazując na brak zamówień.
- Rewolucja w debugowaniu!!! SI analizuje zrzuty pamięci systemu M$ Windows!!!
- Brednie w wiki - hasło Dehomag
- Perfidne ataki krakerów z KRLD na skrypciarzy JS i Pajton
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- U nas propagują modę na SI, a w Chinach naukowcy SI po kolei umierają w wieku 40-50lat
- C++. Podróż Po Języku - komentarz
Najnowsze wątki
- 2025-07-05 Shrek, wzrośnie cena prądu :-)
- 2025-07-05 Warszawa => Senior Frontend Developer (React + React Native) <=
- 2025-07-05 Środa Wielkopolska => SAP FI/CO Internal Consultant <=
- 2025-07-05 Środa Wielkopolska => SAP FI/CO Konsultant wewnętrzny <=
- 2025-07-06 Płacić za wodę ze studni
- 2025-07-06 Kolejny inżynier...
- 2025-07-05 UE ustępuje pod presją Trumpa. Socjaldemokraci: oddaliśmy miliardy
- 2025-07-04 od kiedy można obrażać Plastusia i do kiedy Batyra?
- 2025-07-05 UE ustępuje pod presją Trumpa. Socjaldemokraci: oddaliśmy miliardy
- 2025-07-03 Trybik
- 2025-07-04 Renault Symbioz
- 2025-07-04 Architektura IIIRP: Wyjątkowa, a prymitywniejsza niż stodoła pod zaborami
- 2025-07-04 Warszawa => International Freight Forwarder <=
- 2025-07-04 Wrocław => SAP ABAP Developer <=
- 2025-07-04 Warszawa => Mid/Senior IT Recruiter <=