Mundo Docker: MundoDocker no DevOpsWeek
9 de Janeiro de 2017, 16:33 - sem comentários aindaOi Pessoal,
O Ano começou a todo vapor aqui para o MundoDocker, e hoje queremos convidar a todos para se inscreverem no DevOpsWeek, um dos maiores eventos sobre o assunto DevOps, Desenvolvimento/Infra ágil do Brasil.
Participaremos do evento com a apresentação: Deploy Integrado com Docker, é o assunto do momento, e o objetivo é tirar dúvidas e dar ideias de como o você pode usar Docker para automatizar suas rotinas, e claro acelerar seus processo de desenvolvimento.
Veja abaixo a chamada para o evento que gravamos, te liga:
Ficou interessado? Então te inscreve, o evento é online e gratuito!!! Acesse: http://devopsweek.com.br
Por hoje era isso, e fique atento pois teremos mais novidade aqui no Blog.
Grande abraço!
Gomex: TDD para código de infraestrutura? Acho que não…
7 de Janeiro de 2017, 3:55 - sem comentários aindaApós iniciar um texto sobre a importância de testes automatizados para código de definição de infraestrutura, refleti sobre o uso de TDD nesses casos e cheguei a uma conclusão um pouco polêmica.
Queria deixar claro que esse texto é propositivo e aberto a mudança de opiniões com base nas interações. Meu objetivo é iniciar esse debate, apresentado as minhas conclusões sobre esse assunto e assim possamos juntos concluir algo coletivamente sobre isso.
Antes de pular para conclusão, vamos primeira contextualizar o que é TDD. De acordo com o nosso “nerd alfa” Martin Fowler:
“Test-Driven Development (TDD) é uma técnica para construção de software que o processo de desenvolvimento através da escrita de testes.”
De acordo com esse artigo, é uma prática que força o desenvolvedor a pensar sobre seu código antes de ele escrever ele e que TDD é muito mais sobre design do que teste. (Dica do Luis, no comentário).
Em essência você segue dois simples passos repetidamente:
- Escreva um teste para validar a funcionalidade que precisa adicionar
- Exemplo: Quero uma função para somar dois números, eu escrevo um teste que a soma de 2 + 2 o resultado seja sempre 4. Qualquer resultado diferente desse indica que a função está errada
- Escreva de forma imperativa o código até ele passe nos testes
- Exemplo: Você escreve o código que recebe dois número como parâmetros e soma.
Seguindo essa lógica é fácil pensar que seria ideal isso acontecer também para infraestrutura, certo? Não necessariamente.
Código de infra geralmente é descritivo e não imperativo
Nos exemplos demonstrados acima, temos, a partir de um único teste, uma grande gama de possibilidade de implementação da função a ser testada, ou seja, para um teste de soma de dois números, o código resultante para satisfazer essa validação pode variar bastante.
Desenvolvimento de software normalmente utiliza o modelo imperativo de construção, ou seja, você precisa dizer detalhadamente de que forma ,o que você deseja, seja feito. O código de infraestrutura regularmente segue uma outra linha, que é a descritiva. Você apenas precisa dizer o que deseja e não precisa implementar como isso será executado.
Comparação entre código imperativo e descritivo
Porque não TDD
Levando em consideração que um dos motivadores do TDD seja o auxilio na construção da lógica por trás da solução do teste em questão e no modelo descritivo a lógica é algo raro, fazer um teste para cada definição de infraestrutura me parece um trabalho desnecessário, já que o código de teste seria bem parecido com o usado para atender o teste.
Exemplo:
Quero criar o usuário elmo e o teste seria criado da seguinte maneira com o serverspec
describe user('elmo') do it { should exist } end
O código de infraestrutura para atende o teste acima seria:
user { 'elmo': ensure => present, }
Você há de concordar que esse teste nunca falharia, uma vez que não precisei de nenhuma lógica aqui. Sem falar que eles são bem parecidos na sua escrita, ou seja, no final de contas seria um grande desperdício de tempo.
E se meu código tiver lógica, faz sentido TDD?
Tecnicamente falando, sim, mas na prática nem toda definição terá lógica e ter isso como metodologia de desenvolvimento talvez atrapalhe mais do que gere algum valor para seu processo de desenvolvimento.
Isso quer dizer que não devo ter teste no meu código?
Claro que não! Testes automatizados são bem importantes para a confiança do seu código. Não vou me aprofundar nas razões de ser fazer teste, pois isso foi bem explicado aqui.
Atualização pós comentários
Depois de uma boa interação nos comentários, vale a pena deixar claro algumas coisas que talvez tenham ficado meio solta no artigo e adicionar outras que faltaram no texto ou estavam de forma incorreta.
TDD somente com teste unitário?
A ideia que é TDD seja orientado a teste unitário não foi proposital, mas no caso de teste de infraestrutura esqueci de comentar que testes de integração e outros mais complexos demandam interação com uma infraestrutura provisionada, ou seja, o feedback é bem lento, o que inviabiliza (em minha opinião) o trabalho orientado a teste.
É importante que você crie seu ambiente “do zero” a cada teste, para que você garanta que não tem dado de outro teste ou alguma modificação fora da definição no ambiente. Com isso em mente, é comum encontrar situações que podem demorar até 30 minutos para reconstruir o ambiente, aplicar as definições e então executar os testes.
Se você for utilizar testes de integração ou outros mais complexos pra guiar seu processo de desenvolvimento, ter esse tempo de espera a cada interação “Red-Green-Refactor” seria complicado para o processo de escrita de código.
Mundo Docker: Serviços Windows em Docker
15 de Dezembro de 2016, 12:40 - sem comentários aindaOi Pessoal,
Já vimos em alguns posts, por exemplo este, este e este, como é possível ter seu ambiente Windows em Docker, ou Docker para Windows. Pois bem, a intenção hoje é nos aprofundarmos mais em como é possível portar um ambiente já existente para dentro de containers no Windows, ou seja, veremos como migrar sua aplicação .net que atualmente está em uma máquina virtual para um container, isso de forma bem simples e rápida.
Do início
Antes de tudo, precisamos nos situarmos sobre o uso de algumas ferramentas, e aqui entra a parte fundamental desse processo, que é entender como funciona o Image2Docker, para quem não o conhece, este é um módulo do powershell que possibilita a criação de arquivo(s) Dockerfile(s) a partir de um VHD, VHDx ou ainda uma imagem WIM. Você não precisa estar com a máquina virtual ligada para realizar esse processo, o Image2Docker inspeciona o disco offline coletando informações sobre o que você tem instalado ali, e claro, ele serve apenas para ambiente Windows, então ele já possui uma tabela pré-determinada de aplicações que devem ser verificadas.
Após finalizado o scan, ele monta um Dockerfile baseado na imagem do Windows Server Core (microsoft/windowsservercore), é claro que ele não portará tudo de seu ambiente, por exemplo, se você tem instalado uma base MySQL na VM Windows que escaneou, essa instalação não será portada para o Dockerfile, e consequentemente terá que ser portada manualmente depois. Aqui está uma lista de softwares/aplicações que o Image2Docker busca, e que são suportados por ele:
- IIS e aplicações ASP.NET
- MSMQ
- DNS
- DHCP
- Apache
- SQL Server
Ou Seja, se dentro de seu VHD você possuir algum desses softwares instalados, o Image2Docker gerará o Dockerfile baseado nisso.
Instalação
Há duas formas de instalação, Você pode instalar o módulo nativo do Image2Docker, o processo é simples:
Install-Module Image2Docker Import-Module Image2Docker
Neste caso, se você não tiver todas as dependências instaladas, ele fará essa instalação de forma automática (caso você aprove é claro).
Outro método é você utilizar a última versão diretamente do repositório, neste caso você terá que instalar algumas coisas antes, como por exemplo:
Install-PackageProvider -Name NuGet -MinimumVersion 2.8.5.201 Install-Module -Name Pester,PSScriptAnalyzer,PowerShellGet
Feito isso, basta agora realizar o download do módulo e importa-lo:
mkdir docker cd docker git clone https://github.com/sixeyed/communitytools-image2docker-win.git cd communitytools-image2docker-win Import-Module .\Image2Docker.psm1
É muito importante ressaltar que ele foi desenvolvido para rodar em versões superiores a 5.0 do Poweshell, então se atende a esse detalhe.
Convertendo
Vamos começar as poucos, digamos que você tenha uma máquina virtual com IIS instalado com algumas aplicações e quer porta-la para container Docker, é possível? Sim, o Image2Docker suporta VMs em Windows 2016, 2012, 2008 e 2003, independente da tecnologia utilizada, seja ela ASP.NET WebForms, ASP.NET MVC, ASP.NET WebApi.
Para você rodar Image2Docker, precisará informar alguns parâmetros, dentre eles:
- ImagePath – Localização do VHD, VHDx ou WIM
- Artifact – Que tipo de serviço você quer portar para um Dockerfile, deve ser um dos itens da listagem acima.
- ArtifactParam – Parametro que deve ser utilizado apenas se o artefato for IIS, pois é possível especificar apenas um site a ser portado.
- OutputPath – Localização de onde você salvará o Dockerfile
Chega de papo, vamos ao trabalho, para converter uma VM com IIS e todos os seus sites para um único Dockerfile, basta executar:
ConvertTo-Dockerfile -ImagePath C:\VMS\win-2016-iis.vhd -Artifact IIS -Verbose -OutputPath c:\docker\iis
A saída desse comando deve ser algo como isso aqui:
VERBOSE: IIS service is present on the system VERBOSE: ASP.NET is present on the system VERBOSE: Finished discovering IIS artifact VERBOSE: Generating Dockerfile based on discovered artifacts in :C:\Users\mundodocker\AppData\Local\Temp\287653115-6dbb-40e8-b88a-c0142922d954-mount VERBOSE: Generating result for IIS component VERBOSE: Copying IIS configuration files VERBOSE: Writing instruction to install IIS VERBOSE: Writing instruction to install ASP.NET VERBOSE: Copying website files from C:\Users\mundodocker\AppData\Local\Temp\287653115-6dbb-40e8-b88a-c0142922d954-mount\websites\aspnet-mvc to C:\docker\iis VERBOSE: Writing instruction to copy files for aspnet-mvc site VERBOSE: Writing instruction to create site aspnet-mvc VERBOSE: Writing instruction to expose port for site aspnet-mvc
Ao final da execução do comando, ele gerará um Dockerfile dentro da pasta c:\docker\iis com o seguinte conteúdo:
# Instalar a feature do IIS RUN Add-WindowsFeature Web-server, NET-Framework-45-ASPNET, Web-Asp-Net45 RUN Enable-WindowsOptionalFeature -Online -FeatureName IIS-ApplicationDevelopment,IIS-ASPNET45,IIS-BasicAuthentication... # Adicionar o site mvc no IIS COPY aspnet-mvc /websites/aspnet-mvc RUN New-Website -Name 'aspnet-mvc' -PhysicalPath "C:\websites\aspnet-mvc" -Port 8081 -Force EXPOSE 8081 # Adicionar o site webapi no IIS COPY aspnet-webapi /websites/aspnet-webapi RUN New-Website -Name 'aspnet-webapi' -PhysicalPath "C:\websites\aspnet-webapi" -Port 8082 -Force EXPOSE 8082
Lembrando, no exemplo acima nós portamos todos os sites do IIS para um único Dockerfile, é possível especificar apenas um site, para isso:
ConvertTo-Dockerfile -ImagePath C:\VMS\win-2016-iis.vhd -Artifact IIS -ArtifactParam aspnet-webforms -Verbose -OutputPath c:\docker\iis
Dessa forma, apenas o site chamado: aspnet-webforms será portado para um Dockerfile.
Converti, e agora?
Tendo gerado o Dockerfile, basta você seguir o fluxo normal de criação de imagem Docker, por exemplo:
docker build -t mundodocker/site-webforms .
Dessa forma você criará uma imagem chamada: mundodocker/site-webforms e poderá utiliza-la da mesma forma como as demais, apenas lembrando que essa imagem fará a criação do site e copiará os arquivos do site que havia na VM para dentro do container, vamos rodar:
docker run -d -p 8080:8083 mundodocker/site-webforms
Basta agora, você acessar o endereço de sua aplicação, para isso você terá que saber o ip do container criado, então execute:
docker inspect --format '{{ .NetworkSettings.Networks.nat.IPAddress }}' ID_DO_CONTAINER
Agora sim, basta acessar o ip que esse comando retornará, na porta 8080, algo assim: http://172.28.192.4:8080 e você poderá visualizar a aplicação que você tinha em um VM, agora dentro de um container
Dica final
Imagine que você tenha diversos sites dentro do mesmo IIS, e queira portar cada um para um container diferente, qual seria o método normal? Rodar o comando N vezes até ter todos portados, certo? Pois bem, você pode automatizar isso, criar um script em powershell que faça essa “mágica” sem muito esforço. O script pode ser parecido como este:
$sites = @("aspnet-mvc", "aspnet-webapi", "aspnet-webforms", "static") foreach ($site in $sites) { ConvertTo-Dockerfile -ImagePath C:\VMS\win-2016-iis.vhd -Artifact IIS -ArtifactParam $site -Verbose -OutputPath "c:\docker\$website" -Force cd "c:\docker\$site" docker build -t "mundodocker/$site" . }
Dessa forma ele gerará tanto o Dockerfile para cada site assim como as imagens para cada um.
Gostaram? Ficaram com dúvidas? Deixe nos comentários ou no nosso fórum, que tanto nós quanto nossos leitores poderão ajudar. E como sempre, ajude divulgando o blog.
Grande abraço!
Mundo Docker: Docker 1.13 – O que vem por ai
6 de Dezembro de 2016, 13:25 - sem comentários aindaEai gente!
Você que é leitor do blog já está acostumado a ver por aqui as principais novidades sobre o Docker e tecnologia associadas, e hoje não será diferente. Queremos trazer uma preview sobre as novas features que serão lançadas na versão 1.13 do Docker, como todos os sabem, o ciclo de desenvolvimento dentro do Docker é algo fora da curva, e a cada nova versão alguma novidade aparece, é possível acompanhar esse ritmo pelo próprio github deles.
Mas se você não quiser esperar a versão estável para brincar com as novidades, pode utilizar a versão experimental do Docker, que obviamente não é recomendado para se colocar em produção, mas que pode ser usada para lab sem problema. Para isso, basta você instalar o Docker com o seguinte comando: curl -sS https://experimental.docker.com | sh, com isso você terá acesso a engine com as modificações mais atuais mas em fase de desenvolvimento ainda.
Bom, chega de papo, vamos a uma pequenas lista das novidades do Docker 1.13:
Docker stack
Para quem usa docker-compose ou docker service sabe das diferenças entre essas duas “ferramentas”, e como de certa foram eles deveriam se complementar, não é mesmo? E Essa é uma situação que vinha sendo trabalhada pelos engenheiros do Docker a algum tempo, essa função intermediária vinha sendo testada através do comando docker stack que possibilita criar um serviço dentro do swarm baseado em uma estrutura do docker-compose, ou seja, você conseguirá portar para o cluster de swarm um serviço baseado no docker-compose, isso facilita em muito a administração de seu serviço e claro no deploy do mesmo, pois garante que o serviço esteja rodando independente do nó onde ele está.
Nas versões de teste você tinha que gerar um arquivo .dab (distributed application bundle ou pacote de aplicação distribuída) baseado em seu docker-compose.yml e depois sim você conseguiria fazer deploy dessa stack utilizando o docker. Agora no docker 1.13 isso não é mais necessário, basta você chamar o arquivo docker-compose.yml diretamente no deploy da stack, algo como isso:
# docker stack deploy --compose-file ./docker-compose.yml minhastack
Muito mais simples e rápido não?
Gerenciamento de senha
Ou gerenciamento de segredos, essa é uma função básica dentro de qualquer orquestrator, o Kubernetes já possuía esse conceito e aplicação á algum tempo já, e agora o docker também implementa essa funcionalidade.
Mas afinal, onde vou usar isso? Sua aplicação usa senha não usa? Seja para banco, API, etc, qualquer aplicação usa senha de acesso a algum serviço em algum momento, e com você faz hoje com Docker? Provavelmente via variável de ambiente ou compartilhando um arquivo com o container, existem outras formas, como ferramentas as a service de gerenciamento de identidade.
Agora no docker 1.13 você pode definir uma secret que pode ser utilizada pelo seu serviço dentro do swarm, exatamente da mesma forma que o Kubernetes usa. Para isso foram adicionados quatro comandos novos, são eles:
- docker secret create
- docker secret inspect
- docker secret ls
- docker secret rm
Veja um exemplo de como criar uma secret para ser utilizada dentro de seu serviço
# echo "123456" | docker secret create senha-banco
Agora um exemplo de como utilizar essa secret em seu serviço:
# docker service create --name app --secret senha-banco ubuntu
Dentro do container será criado um arquivo em /run/secrets/senha-banco
com a informação da senha, isso é claro apenas dentro do container, sem precisar mapear nada do host para o container.
# docker exec -it app cat /run/secrets/senha-banco
123456
Um detalhe muito importante é: As secrets podem ser utilizadas apenas dentro de serviços, se você criar um container com o docker run, vão não poderá utilizar essa funcionalidade.
Novo parâmetro de rede no Swarm
Essa talvez seja uma das melhorias mais importante no core do docker, pois permite que você adicione uma rede do Swarm mesmo se o container for criado fora de um serviço, ou seja, criado da forma tradicional com o docker run.... Mas afinal, por que isso é importante? É importante porque agora é possível adicionar um container a mesma rede do serviço criado no Swarm, isso é muito útil para debugs ou até mesmo testes de ambiente.
E como fica agora então? Simples, veja:
# docker network create --driver overlay --attachable rede-plugavel
Com o comando acima nós criamos uma rede overlay do Swarm, e a diferença agora é o parâmetro –attachable, que permite que essa rede seja plugada em qualquer container criado, e no comando abaixo nós plugamos um container a essa rede:
# docker run --rm -it --net rede-plugavel centos ping google.com
Plugins
Finalmente alguns plugins que estavam sendo testados e aprimorados foram disponibilizados como estáveis dentro da engine do Docker. Dentre ele podemos destacar o Flocker e o Weave, que agora tem integração total com docker.
Docker Daemon –experimental
Até então para você poder utilizar comandos e opções em desenvolvimento/teste do docker, você teria que instalar a versão experimental ou test da engine, mas agora basta você iniciar o daemon do docker com a opção –experimental, com isso será habilitado em momento de execução as opções da versão experimental, veja:
Melhorias no docker service
Essas, na verdade, são algumas das melhorias que a comunidade pediu ao longo do meses, uma delas tem relação com o update da imagem no update do serviço, para quem não notou, quando um serviço é atualizado (até então) você precisava executar um update com alguns parâmetros a mais para poder atualizar o serviço com uma nova imagem, na nova versão esse processo pode ser feito passando o parâmetro –force junto, o docker service update já verificará se há uma versão mais recente da imagem e atualizará o serviço baseado nisso.
Novo parâmetro no docker service
Além das melhorias no docker service, foi acrescentado também um novo parâmetro. Hoje nós acessamos um serviço através da porta exposta do mesmo, que você pode definir com o parâmetro –publish, no docker 1.13 será possível você definir de forma mais detalhada essa regra, isso deve-se ao novo parâmetro –port, que, da mesma forma que o –mout, tem sintaxe parecida com csv, onde você define item=valor,item=valor… Veja um exemplo:
# docker service create --name servico_web --port mode=ingress,target=80,published=8080,protocol=tcp
Dessa forma você tem, de forma mais clara, as definições de porta do serviço.
Outras novidades
Dentre outras novidades do docker 1.13 podemos destacar ainda algumas que tem bastante relevância para quem o utiliza, como por exemplo:
- Cache de Layer para o Build: Para que gera muitas imagens, sabe que esse era um problema a ser resolvido, exemplo: geramos um imagem agora com o docker build, caso tenha que modificar essa imagem todas as layers anteriores a alteração não eram buildadas novamente, o docker build usava o cache para elas. Agora digamos que mandamos essa imagem para outro host e queremos fazer outra modificação nela, o que ocorre? Exatamente, todas as layers são buildadas novamente, isso pelo fato do docker não ter naquele host o cache de build dessa imagem. Parece ser trivial, mas quando se quer ganhar tempo, não é. No docker 1.13 você pode especificar na hora do build de onde o docker poderá buscar o cache de build, como por exemplo:
docker pull imagem:v1.0 docker build --cache-from imagem:v1.0 -t imagem2:v1.1 .
Dessa forma o build da nova imagem utilizará o cache da imagem original, compilando assim apenas as layers diferentes.
- A instrução MAINTAINER foi removida do Dockerfile, agora essa informação deve ser utilizada através de label;
- Foi adicionado um novo comando, ainda experimental, que é o docker service logs para visualizar os logs do serviço e não do container em si.
- Outra adição do docker service foi o parâmetro –rollback que tem por objetivo realizar o update do serviço através de uma versão anterior a atual;
- Remoção de container velhos através do docker system (ainda não há mais informações sobre como esse comando funcionará para remoção de containers antigos, então ficamos ligados no lançamento)
Ok Cristiano, e quando será lançada? Não há uma data 100% definida, o que se sabe é que será lançada até inicio de Janeiro de 2017, então pode ser que seja lançada hoje mesmo . Pode haver mais modificações? Claro, sempre há e com certeza as novidades que trouxemos hoje serão melhor explicadas após o lançamento oficial, então o jeito é ficar ligado aqui no blog e claro no site do ofiical do docker.
Grande abraço!
Gomex: Escrevendo um livro digital como entrega contínua parte 2
2 de Dezembro de 2016, 17:37 - sem comentários aindaNesse artigo pretendo continuar a compartilhar um pouco da minha experiência de escrever um livro digital. Esse é o segundo artigo da série. O primeiro segue aqui.
Escolhendo a plataforma
Agora que já sabemos qual nosso assunto, foco e público alvo, só nos basta começar a escrever. E nesse momento você deve estar se perguntando qual melhor forma de fazer isso.
Eu não fiz uma pesquisa muito rebuscada sobre isso e acabei usando o primeiro que me foi apresentado. O leanpub é uma plataforma fantástica! Ela tem tudo que eu preciso e talvez você devesse dar uma chance a ela. Segue abaixo as coisas que acho bem relevante nela:
- Você escreve em markdown e ela gera seus livros em PDF, Mobi (Formato pra Kindle) e ePub (Formato para maioria dos e-readers),
- Ela pode exibir seus livros online na plataforma,
- Você pode monetizar seus livros no Leanpub (você informa valor mínimo de contribuiçao, que pode ser zero), ele cobra uma porcentagem por cada “compra” e eu resgato o dinheiro usando paypal,
- Você pode integrar com o Dropbox e Github para atualizar os arquivos markdown que serão usados para gerar seus livros,
Falando um pouco melhor sobre integração do Leanpub, eu gostei muito da possibilidade de manter meu livro no github. Isso pra mim foi crucial para eu de fato abrir o “código” do meu livro de forma mais fácil, ou seja, caso você deseje escrever um artigo novo no meu livro basta fazer um fork, atualizar e me mandar um PR no meu repositório.
Quando me cadastrei no Leanpub, ainda era de graça, mas hoje é um custo único de $99,00 por livro, que você paga no momento da criação do mesmo. Eu ainda acho que vale a pena, pois até o momento já arrecadei aproximadamente $500.
O Leanpub mantém o email das pessoas que baixam seu livro, ou seja, a cada vez que você atualizar o conteúdo eles podem ser notificados para baixar a versão mais nova e você pode inclusive informar no “Release Notes” o que tem de novidade nessa nova versão.
Resumindo, o leanpub pra mim tem sido uma ferramenta completa pra lidar com lançamento do meu livro.
Como opção gratuita ao Leanpub, temos o Papyrus:
Depois que descobri que o Leanpub se tornou pago, procurei uma opção sem custos e encontrei essa, mas ainda não utilizei para dar um bom feedback.
Caso você tenha usado o Papyrus e quiser nos ajudar, comente nesse artigo.
Porque meu livro é livre e pode ser baixado de graça
Quando comecei a escrever, pensei bastante sobre conhecimento aberto, preço do material e afins. Como falei no primeiro artigo, eu fiz de uma forma que não impactou exageradamente meu tempo livre e assim essa pressão por monetizar esse tempo gasto foi menor em mim.
Eu sei que nos trabalhadores vendemos a fatia do nosso tempo para viver nessa sociedade capitalista, mas quebrar essa lógica sempre que possível é um desafio gostoso que eu sempre que posso tentarei.
Me ajudou saber que nenhum dos escritores que escrevem livros técnicos ganharam dinheiro o suficiente para deixá-los “ricos”, mesmo aqueles que dedicaram bastante tempo diário, que poderia estar com suas crianças, pessoas companheiras, amigas e afins. Caso o dinheiro fosse grande o suficiente ele poderia viabilizar a “compra” de tempo no futuro, mas se nem isso é válido, qual motivo real de cobrar por livros digitais?
Alguns escritores me falaram que acham injusto pessoas que podem pagar não fazerem isso, mas meu contraponto é que pessoas que não podem pagar simplesmente não tem acesso aos livros pagos e o pior, as licenças proíbem compartilhamento para grupos de estudo, projetos em movimentos sociais e afins.
O meu maior objetivo na escrita do livro era compartilhar o que sei e me estabelecer como referência técnica no assunto. Qual melhor forma de fazer isso senão permitindo que meu livro circule da forma mais fácil e rápida possível?
Caso meu livro fosse completamente fechado eu fatalmente acabaria gastando uma boa fatia desse dinheiro obtido para impulsionar ele nas redes sociais e propaganda em sites. Sem contar que a maioria das pessoas que pensasse na possibilidade de escrever sobre meu livro, pensariam duas vezes, pois eles achariam que estaria colaborando financeiramente com alguém e não estaria ganhando nada em retorno. Infelizmente é assim que somos construídos para pensar no contexto dessa sociedade que “gira em torno” do dinheiro.
Porque eu permito que as pessoas ganhem dinheiro com meu livro
Um outro assunto polêmico é viabilizar na sua licença que ele possa ser usado comercialmente, ou seja, agora meu livro pode ser usado como base para um curso e o livro até ser usado como material didático, por exemplo. Tudo isso pode ser comercializado sem nenhum problema. Só tenho duas ressalvas:
- A licença não pode ser modificada, ou seja, caso use meu livro, o que você modificou, adicionou ou afins deve ser liberado ainda livre,
- Você deve mencionar que se baseou no meu material, citando eu como autor.
Eu faço isso por um motivo simples: As empresas que eu me incomodariam de usar meu material normalmente fazem isso mesmo em produtos fechados, pois eles tem força o suficiente para fazer isso sem sofrer consequências suficientes para incomodá-los. Sendo assim eu preferir que pessoas que precisam obter uma granam o façam comercializando meu livro.
Comercializar meu livro reforça a ideia que eu quero que mais pessoas tenham acesso a ele. Já pensou que massa seria alguém imprimir várias cópias do meu livro e lançar ele numa feira do livro no interior do Paraná? Eu nunca chegaria lá, mas uma pessoa motivada por ganhos financeiros fez isso e me ajudou bastante. Agora sou conhecido no interior do Paraná!
Possibilitar a comercialização é viabilizar que mais pessoas ajudem no projeto, pois sabem que poderão usar esse material para seu curso técnico, aula na faculdade ou afins, sem que isso inflija de alguma forma nenhuma lei. Não que infligir lei seja um problema para algumas pessoas (eu incluso), mas o ponto aqui é permitir e não negar.