CDN: Identificando IP de um usuário
8 de Agosto de 2013, 14:40 - sem comentários ainda<p>Quando um site usa uma <a href="http://pt.wikipedia.org/wiki/Content_Delivery_Network">CDN</a> para fazer cache e/ou aceleração as vantagens são bem conhecidas, mas algumas vezes é necessário ajustar uma ou outra coisa para tudo continue funcionando. Um exemplo é o servidor web do site deixa de receber requisições diretamente do usuário porque agora tem os servidores da CDN intermediando essa comunicação. Então, nos logs do servidor web estará um IP de um servidor da CDN ao invés do IP de um usuário.</p> <p><img src="http://www.fernandoike.com/images/cdn.png" /></p> <p>Para resolver esse problema, uitas CDNs enviam um cabeçalho HTTP extra de suas requisições para o servidor web do site, esse cabeçalho é o True-Client-IP.</p> <p>Abaixo dois exemplos (<a href="http://http.apache.org">Apache</a> e <a href="http://www.nginx.org">nginx</a>) de configuração do Log para registrar o True-Client-IP.</p> <h4>Apache</h4> <pre> [...] LogFormat "%v %h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\" \"%{true}i\" %q" site.com CustomLog ${APACHE_LOG_DIR}/teste_access.log site.com [...] </pre> <h4>nginx</h4> <pre> [...] log_format teste '$remote_addr - $remote_user [$time_local] ' '"$request" $status $bytes_sent ' '"$http_referer" "$http_user_agent" ' '$http_true_client_ip'; access_log /var/log/nginx/teste.com.log site.com; [...] </pre>
PostgreSQL tuning - Prelúdio
6 de Agosto de 2013, 0:00 - sem comentários ainda<p>Normalmente ao pensar em melhorar a performance do banco de dados, muitos esquecem de modificar alguns parâmetros e configurações do Sistema Operacional e outras coisas relacionadas a infraestrutura de TI. Não dar a atenção devida para essas coisas é que elas podem impactar o desempenho do banco de dados e você estar tão focado em melhorar o banco de dados que não considera-os como a causa raiz.</p> <p>Bom, então a idéia aqui é ser uma etapa prévia antes de mexer nas configurações do <a href="http://www.postgresql.org/">PostgreSQL</a>, portanto considere como um ponto de partida. Cada aplicação e arquitetura terá uma configuração específica do PostgreSQL para que tenho o melhor desempenho possível.</p> <h3>Adote um método para fazer os ajustes de performance.</h3> <p>Infelizmente não existes muitos números mágicos (ok, existe alguns números mágicos mas não é caso neste momento). Para fazer os ajustes para melhorar o desempenho do PostgreSQL e consequetemente da aplicação é necessário fazer vários testes em muitas variáveis. Fazer alterações em muitas variáveis ao mesmo tempo pode levar muito mais tempo do que fazer alterações em poucas ou uma variável e observar se obteve ganho de performance ou não. Portanto, adote uma metodologia, faça uma mudança por vez e teste! Anote os resultados, faça outra alteração e compare coms os resultados anteriores. Assim poderá comparar e verificar quais são os melhores ajustes em determinados cenários que imaginar que a aplicação faz.</p> <p>Vale qualquer forma de registro, até papel de padaria!</p> <h3>Armazenamento</h3> <p>Tão ou mais importante que ter uma servidor com uma capacidade tão grande de processamento é ter a parte de armazenamento (discos/storages) bem plenajada. É muito comum usar Storages com um único Array e compartilho entre as diversas aplicacṍes da instituição.</p> <p>Como aparentemente o Storage tem I/O infinito, geralmente é relegado algum planejamento de como as aplicações ou base de dados irão ocupá-lo. Em situações de grande uso de I/O (escrita ou leitura) é importante criar grupos de discos (arrays) considerando usar as partes mais rápidas do Storage para as bases ou operações críticas e com conexões de fibras dedicadas para o servidor PostgreSQL.</p> <p> O Telles escreveu um <a href="http://savepoint.blog.br/postgresql-discos-cia/">bom texto</a> sobre discos, recomendada a leitura.</p> <p>Considere sempre usar “canais” dedicados de comunicação entre o servidor do banco de dados e o armazenamento. Exemplo: Caso esteja usando um sistema de arquivo de rede (<a href="http://pt.wikipedia.org/wiki/Network-Attached_Storage">NAS</a>) para o banco de dados, considere segregar em uma rede dedicada à eles para que não haja concorrência de tráfego de rede com outros serviços e/ou aplicações. Caso esteja usando comunicação via Fiber Channel (<a href="http://pt.wikipedia.org/wiki/Rede_de_%C3%A1rea_de_armazenamento">SAN</a>), tente deixar as conexões físicas dedicadas entre o servidor de banco de dados, switch fiber channel e o storage.</p> <p>Armazenamento de banco de dados é um tema tão vasto que facilmente poderia ser um Livro de centenas de páginas mas por enquanto ficamos por aqui…</p> <h3>Habilitar ou não o HyperThreading</h3> <p> Para o PostgreSQL não faz diferença se o <a href="http://pt.wikipedia.org/wiki/Hyper-threading">HyperThreading</a> habilitado ou não, ele usará o número máximo de processadores que o Sistema Operacional disponibilizar.</p> <h3>Sistema Operacional</h3> <p>É simples, use Unix/Linux e que seja 64 bits. Entendo que exista questões de usar um Sistema Operacional “homologado” para o servidor ou Storage mas se quer o máximo de performance seria melhor usar <a href="http://www.centos.org/">CentOS</a> ou [Debian<a href="http://www.debian.org/">7</a> ou mesmo um <a href="https://www.archlinux.org/">ArchLinux</a>.</p> <p>Antes do tuning do banco de dados, tuning do Sistema Operacional.</p> <p>Isso é coisa básica mas extremamente importante, afinal é impossível aumentar o<em>Shared Buffer</em> do PostgreSQL sem aumentar a memória compartilhada do Linux. Considere aumentar a memória compartilhada (<em>Shared Memory</em>), <em>semáforos</em>, buffers de rede, scheduler I/O, etc.</p> <h4>Memória compartilhada (shared memory)</h4> <p>Mais ou menos 25% da memória total é a resposta padrão mas pode ser interessante iniciar os ajustes com valor menor. Algo entre 15% e 20% do total disponível da RAM e depois ajustar para um valor maior. Exemplo para 10GB:</p> <pre> #sysctl -w kernel.shmmax=109951162777 </pre> <h4>Usando Swap somente em último caso</h4> <p> O Kernel Linux por padrão usa a memória <a href="http://pt.wikipedia.org/wiki/Mem%C3%B3ria_virtual">Swap</a> (“extensão” da memória RAM na HD, é muito) antes mesmo de esgotar o espaço livre da memória RAM. Para utilizar a Swap somente em último caso:</p> <pre> #sysctl -w vm.swappiness=0 </pre> <h3>Rede</h3> <p> Supondo que o servidor tem placas de rede de 10GBits/s.</p> <pre> #systcl -w net.core.rmem_default = 8388608 #systcl -w net.core.rmem_max = 8388608 #systcl -w net.core.wmem_default = 8388608 #systcl -w net.core.wmem_max = 8388608 #systcl -w net.core.netdev_max_backlog = 10000 </pre> <h4>Ajustes na pilha de rede.</h4> <pre> #systcl -w net.ipv4.tcp_max_syn_backlog = 40000 #systcl -w net.core.somaxconn=4000 #systcl -w net.ipv4.tcp_timestamps = 0 #systcl -w net.ipv4.tcp_sack = 1 #systcl -w net.ipv4.tcp_window_scaling = 1 #systcl -w net.ipv4.tcp_fin_timeout = 15 #systcl -w net.ipv4.tcp_keepalive_intvl = 30 #systcl -w net.ipv4.tcp_tw_reuse = 1 </pre> <h3>Scheduler I/O</h3> <p>O Kernel Linux tem vários tipos de scheduler, por padrão atualmente é o <a href="http://en.wikipedia.org/wiki/CFQ">CFQ</a> mas para operações intensivas de I/O o <a href="http://en.wikipedia.org/wiki/Deadline_scheduler">Deadline</a> tem um resultado melhor.</p> <pre> #echo deadline > /sys/block/sda/queue/scheduler </pre> <h3>Limite de Arquivos Abertos (Open Files Limit)</h3> <p> Acontece com muita frequencia alterar a configuração do Linux, servidor de aplicação, algoritimos, banco de dados e esquecer de alterar o “Limite de Arquivos Abertos”. Não alterá-lo significa numa analogia grosseira dizer que “você está andando de Porche com o freio de mão puxado.”. Este item é importantíssimo porque se estiver com valores relativamente baixos, nenhuma ferramenta de monitoramento irá detectar isso como um gargalo de desempenho.</p> <p>Para configurar o usuário <strong>postgres</strong> com um limite maior:</p> <p>Edite o <em>/etc/pam.d/common-session</em>, acrescente, salve e feche o arquivo.</p> <pre> session required pam_limits.so </pre> <p>Edite o <em>/etc/security/limits.conf</em> e acrescente as linhas abaixo:</p> <pre> * soft nofile 65536 * hard nofile 65536 </pre> <p>Lembre-se de salvar, fechar o arquivo e reinicar para que as alterações tenham efeito. Para saber mais, vale ler a <a href="http://docs.basho.com/riak/latest/ops/tuning/open-files-limit/">documentação</a> do Riak sobre isso.</p> <h3>Sistema de Arquivo</h3> <p>Esse é um difícil dizer qual é a melhor opção, eu não conheço benchmarks recentes mas o benchmark que fiz algum tempo atrás apontou que para bases de dados pequenas e de pouco usuários simultâneos é melhor usar <a href="http://pt.wikipedia.org/wiki/Ext4">Ext4</a>. No cenário de base de dados grandes e muitos usuários simultâneos o <a href="http://pt.wikipedia.org/wiki/XFS">XFS</a> tem uma performance melhor.</p> <p>Também é imporante fazer outros ajustes como modificar a montagem dos discos para desconsiderar o timestamp da criação/edição de arquivos e diretórios. Exemplo de entrada no <em>/etc/fstab</em>:</p> <pre> [...] /dev/sdd1 /opt/pg/9.3/db xfs defaults,noatime,nodiratime,nodev 0 0 [...] </pre> <p>Se você tiver alguma informação do <a href="https://btrfs.wiki.kernel.org/index.php/Main_Page">Brtfs</a>, Ext4 e XFS com benchamrks mais novos, comente aí. :D</p> <h3>Conclusão</h3> <p>Pensar em tuning de banco de dados sem considerar os ajustes de desempenho de toda arquitetura envolvida é como colocar um motor de Porsche num Fusca. Tuning é uma tarefa contínua enquanto a aplicação existir. Existe bons textos sobre o tema, recomendo a leitura de alguns:</p> <ul> <li><a href="http://www.redbooks.ibm.com/abstracts/redp4285.html">Red book Linux Performance and Tuning Guidelines</a></li> </ul> <p>Livro antigo mas com informações preciosas.</p> <ul> <li><a href="http://docs.basho.com/riak/latest/cookbooks/Linux-Performance-Tuning/">Linux Performance Tuning - Riak - Basho</a></li> </ul> <p>Bem didádico, as dicas estão aplicadas para o Riak mas vale como referência.</p> <ul> <li><a href="http://docs.neo4j.org/chunked/stable/linux-performance-guide.html">Linux Performance Guide - Neo4J</a></li> </ul> <p>Também bem didático mas aplicado para o Neo4J.</p> <p>Neste texto tem uma visão bem particular, se tiver alguma sugestão, crítica ou correção. Faça! :)</p>
Melhorar peformance do site aumenta audiência
2 de Agosto de 2013, 0:00 - sem comentários aindaHá +- um mês eu comecei a fazer otimizações no servidor e no Octopress (O CMS do meu blog) como parte dos estudos de Web Performance. No mês de Junho de 2013 era 352 vistantes, 535 page views (páginas vistas) e o tempo médio de renderização da página era por volta de 11 segundos. Em Julho de 2013 fiz várias otimizações no blog e os números aumentaram um pouco: 706 visitantes, 1.301 pages views, e tempo médio de renderização da página foi 7,48 segundos. Aumento expressivo para um blog de pouca audiência, não?
Abaixo uma tabela simples com os dados consolidado.
Dados/Mês | Junho | Julho | Percentual |
---|---|---|---|
Visitantes | 352 | 706 | 100,57% |
Page views | 535 | 1.301 | 143,18% |
Doc Complete | 11 seg. | 7,48 seg | 68% |
Tempo/Visita | 1:08 seg. | 1:32 seg. | 36,15% |
Página/Visitantes | 1,52 | 1,84 | 21,24% |
Como as principais otimizações no blog foram realizadas no final de Julho, é provável que a audiência aumente um pouco mais no mês de Agosto. Se fosse um portal de notícia ou comércio eletrônico o alvo das otimizações, provavelmente aumentaria audiência ou a conversão de vendas segundo o estudo do Walmart dos EUA.
Essas mudanças ficam mais visíveis com o gráfico comparativo do Google Analtyics.
Os textos blog relacionados à Web Performance:
- Fazendo Seu Site Voar Com Pagespeed
- Slides da apresentação sobre Web Performance no Campus Party
- Video no Eventials sobre Web Performance
- Wordpress Para Octopress: Comparação De Performance
Fazendo seu site voar com Pagespeed
31 de Julho de 2013, 0:00 - sem comentários aindaFront End Optimization (FEO) é um dos buzzwords mais comentados nos últimos tempos. São vários métodos/técnicas que permite ao navegador carregar mais rapidamente as páginas HTML.
De certa foram, FEO é uma área parecida com segurança para uma equipe de desenvolvimento. Exige muito tempo e atenção aos detalhes mas se incorporado, permite ganhos visíveis de audiência, conversão de vendas, etc.
Muito avaliam que investir em FEO é um desperdício porque o mundo (em sua maioria) está indo em direção aos aplicativos nativos das plataformas móvel (mobile) ao invés de concentrar todos os esforços em aplicações base HTML(5). Fato ou não as duas formas coexistirão mas isso fica para um próximo texto. Voltando ao assunto título deste texto: Pagespeed
Ele é um serviço de otimização de sites alterando as páginas de um site para obter a melhor performance possível usando coisas como: CSS sprites, otimização de imagens, defer de javascript, minify, etc. Se você não quiser usar o serviço e usá-lo diretamente no seu servidor web pode pois o código do módulo é Código Aberto (Apache License). A restrição é que é que o módulo está disponível para Nginx e Apache.
Os testes foram realizados usando Apache e Debian Wheezy e meu blog com Octopress. Na página do módulo tem os detalhes da instalação, basicamente é baixar o pacote .deb e instalá-lo.
#wget -c https://dl-ssl.google.com/dl/linux/direct/mod-pagespeed-stable_current_amd64.deb #dpkg -i mod-pagespeed-stable_current_amd64.deb
Por padrão o módulo não é ativo, pode fazê-lo diretamente no VirtualHost ou a ativar para todos os existentes. Mas cuidado, não vá alterar habilitar para todos os sites pois algumas alterações podem quebrar o layout do site. Faça uma homologação antes. Para este teste foi alterado o pagespeed.conf em /etc/apache2/mods-avaliable/pagespeed.conf de Off para On e depois ativado com a2enmod.
#vi /etc/apache2/mods-available/pagespeed.conf
# Turn on mod_pagespeed. To completely disable mod_pagespeed, you # can set this to "off". ModPagespeed on [...]
#a2enmod pagespeed
A documentação é bem detalhada e recomendo uma leitura dela. Se quiser ver como um filtro é aplicado, pode ver no Modpagespeed. Os detalhes de cada uma pode acessar aqui.
#vi /etc/apache2/site-avaliable/www.fernandoike.com
[...] ModPagespeedEnableFilters combine_css ModPagespeedEnableFilters combine_javascript ModPagespeedEnableFilters rewrite_css,sprite_images ModPagespeedEnableFilters rewrite_javascript ModPagespeedEnableFilters inline_css ModPagespeedEnableFilters inline_javascript ModPagespeedEnableFilters rewrite_images ModPagespeedEnableFilters insert_img_dimensions ModPagespeedEnableFilters remove_comments ModPagespeedEnableFilters extend_cache ModPagespeedEnableFilters remove_quotes ModPagespeedEnableFilters defer_javascript ModPagespeedEnableFilters flatten_css_imports ModPagespeedEnableFilters lazyload_images ModPagespeedEnableFilters recompress_images ModPagespeedEnableFilters move_css_above_scripts ModPagespeedDomain http://www.fernandoike.com [...]
Feito as configurações, vamos aos resultados. Eles foram feito com o
Webpagetest (WPT) e todos baseados no Firefox e uma conexão de
5 Mbit/s.
Teste feito em Virgínia nos EUA sem PageSpeed.
O Document Complete (tempo que o navegador levou para deixar a página “pronta” para usar) ou Onload foi entregue me 3,972 segundos, 56 requisições e 1.535 Kbytes de tamanho. Um bom resultado para um blog.
Teste feito em Virgínia nos EUA com PageSpeed.
Teste feito em São Paulo sem PageSpeed.
Teste feito em São Paulo com PageSpeed.
Tabulando para facilitar a comparação:
EUA
Virginia | s/ PageSpeed | c/ PageSpeed |
---|---|---|
Doc Complete | 3,972 seg. | 2,451 seg. |
Requisicoes | 56 | 39 |
Tamanho | 1.535 Kbytes | 646 Kbytes |
Brasil
São Paulo | s/ PageSpeed | c/ PageSpeed |
---|---|---|
Doc Complete | 6,360 seg. | 4,696 seg. |
Requisicoes | 51 | 40 |
Tamanho | 1.535 Kbytes | 941 Kbytes |
O resultado com PageSpeed em Virgínia teve uma redução drástica no tamanho da página, em torno de 42%, 39% no Doc Complete e 30% em requisições.
Agora em São Paulo as reduções foram: 39% no tamanho da página, 26% no Doc Complete e 22% de requisições.
Fazendo configurações básicas dos filtros do PageSpeed consegue uma boa
otimização. Considerando o baixo esforço para implementá-lo, é altamente
recomendável mas é importante homologar as alterações feitas por ele porque
pode quebrar o layout das páginas.
A distância geográfica impacta na experiência do usuário, como o servidor do teste está em Dallas e Virgínia é mais perto que São Paulo, é perceptível o impacto no tempo do Doc Complete ao comparar as duas localidades. Existem maneiras de melhorar o resultado de São Paulo se usar uma CDN mas isso fica para outro texto.
Fim do The H
29 de Julho de 2013, 0:00 - sem comentários aindaSemana passada o “The H” fechou suas portas. No últimos anos ele foi uma boa fonte de informação do que acontece no mundo do Código Aberto/Software Livre. Seus textos eram bem detalhados, principalmente os relacionados ao Kernel Linux.
O último texto publicado foi sobre dez melhores histórias. Vale a leitura.
Uma pena mesmo, junto com o Slashdot e o LWN fazia uma boa trinca.
Estou um pouco mais ágil: Scrum
20 de Julho de 2013, 0:00 - sem comentários aindaHá um pouco mais de um ano atrás eu decidi que iria mudar o foco da minha carreira profissional, desde então tenho estudado e aplicado em alguns projetos pessoais que tem gerado boas surpresas.
Essa aqui abaixo é uma delas. :)
Claro que um certificado com esse não é que define se alguém é ou poderá ser um bom ScrumMaster. Venho aplicando Scrum em alguns projetos já algum tempo, mas agora posso dizer que “oficialmente” sou um ScrumMaster.
Debian e sua CDN (2)
18 de Julho de 2013, 0:00 - sem comentários aindaLembra do post anterior sobre a(s) [CDN(s)][] do [Debian][]? Se não lembra ou não leu, vale ler antes desse aqui. ;)
O anterior comentava um pouco do funcionamento da implantação do CDN baseada em DNS. Dessa vez é comentar um pouco sobre outra “forma” de CDN, esta é baseada em redirecionamento HTTP. A método para usuário é simples, é apenas um redirecionamento (Código HTTP 302) para o local onde o serviço identifica que o usuário terá melhor desempenho para baixar os pacotes Debian.
Um teste simples realizado no Brasil.
fike@klatoon:~$ curl -I http://http.debian.net/debian/ HTTP/1.1 302 Moved Temporarily Date: Thu, 18 Jul 2013 01:25:40 GMT Server: Apache/2.2.16 (Debian) Vary: x-web-demo,Accept-Encoding X-IP: 179.186.50.212 X-AS: 18881 X-URL: X-Arch: X-Country: BR X-Continent: SA X-Std-Dev: 12.0185273640326 X-Population: 4 X-Closest-Distance: 0 X-Distance: 0 X-Match-Type: country Link: ; rel=duplicate; pri=1; depth=0, ; rel=duplicate; pri=1; depth=0 Location: http://debian.c3sl.ufpr.br/debian/ Content-Type: text/plain
Na resposta do servidor a requisição realizado pelo curl tem vários cabeçalhos que ajudam entender o funcionamento. O servidor do http.debian.net identifica o IP de origem da requisição, o país, o Autonomous System (AS), etc. Ao final tem o cabeçalho Location apontando qual será a URL que responderá a requisição.
Abaixo o mesmo teste mas realizado nos EUA.
fike@midstorm:~$ curl -I http://http.debian.net/debian/ HTTP/1.1 302 Moved Temporarily Date: Thu, 18 Jul 2013 01:26:07 GMT Server: Apache/2.2.16 (Debian) Vary: x-web-demo,Accept-Encoding X-IP: 74.50.55.64 X-AS: 36024 X-URL: X-Arch: X-Country: US X-Continent: NA X-Std-Dev: 3.5960358730135 X-Population: 15 X-Closest-Distance: 13.434 X-Distance: 13.434 X-Match-Type: country Location: http://debian.gtisc.gatech.edu/debian/ Content-Type: text/plain
Interessante que no teste dos EUA tem um pouco mais de informações que melhoram a escolha do melhor espelho (mirror) do repositório Debian para para a requisição.
Se quiser conhecer um pouco mais pode entrar na página do projeto no Github. Ele bem simples e o Raphael Geissert ficará feliz com informações de bugs, patches, etc. ;)
Ah! Já estava esquecendo, se quiser testá-lo, basta adicionar uma linha no /etc/apt/sources.list. No meu caso estou usando para o Sid/Unstable.
deb [arch=amd64,i386] http://http.debian.net/debian/ unstable main contrib non-free
Instalando LOIC no Debian
12 de Julho de 2013, 0:00 - sem comentários aindaNos últimos meses tem ocorrido muitas solicitações de clientes para fazer testes de carga ou segurança usando LOIC. LOIC (Low Orbit Ion Cannon) é um software desenvolvido em C# e ele tem o objetivo de fazer ataques de negação de serviço (Denial-of-Service) ou ataques de negação de serviço dstribuído (Distributed Denial-of-Service).
O LOIC possibilita ataques usando TCP, UDP ou HTTP, ele ou alguns derivados dele (como JS LOIC) são muito usados pela anonymous como represália ou protesto contra algum site de empresa, governo ou instituição política.
Bom, o LOIC para meu trabalho nesses clientes tem a função de avaliar a capacidade de contenção/mitigação de ataques de DOS/DDOS. Geralmente avalia-se se o Firewall, IPS (Intrusion Prevention System), WAF (Web Application Firewall), etc. conseguem conter esse tipo de ataque. Caso seja identificado que não, é entregue um relatório com propostas de mudança na infraestrutura do cliente.
Ops… Voltando ao assunto título deste artigo, a instalação no Linux é possível de duas maneiras: instalando WINEe ou instalando o MONO. No meu caso instalei o MONO e minha distribuição é o Debian.
O procedimento é relativamente simples:
#aptitude install mono-complete
Para baixar o LOIC pode fazer acessando a página do projeto no Sourceforge
Após baixar, descompacte e execute o LOIC usando o MONO.
$unzip LOIC-1.0.7.42-binary.zip $mono LOIC.exe
Como você pode ler, a instalação é simples. O LOIC também não é complexo como pode ver no screenshot do Debian instalado no meu computador.
Mapa dos tweets pelo mundo
8 de Julho de 2013, 0:00 - sem comentários aindaVisualização de dados é uma das que gosto no mundo informatizado, no Mapbox tem uma visualização dos tweets (ato de escrever no Twitter), praticamente em tempo real. Essa forma de ver os dados do twitter é do Gnip.
Alguns exemplos:
Mundo
As áreas mais claras são onde tem maior concentração de pessoas usando o twitter. Neste mapa mundi é perceptível as costas Leste e Oeste dos EUA estão claras, assim como Europa e região do Japão. O Brasil tem maior uso na região Sudeste.
Costa Leste dos EUA
Região Sudeste do Brasil
Hangout com Bruno Domingues adiado...
6 de Julho de 2013, 0:00 - sem comentários aindaMuito estranho, muito estranho mesmo… :)
Toda vez que tentamos fazer o Hangout com o Bruno Domingues da Intel acontece alguma problema. Ele teve um probleminha no meio da transmissão do hangout e tivemos que adiar novamente.
Desconfio que algum alienígena está usando um artefato concentrador de tempestade magnética para causar tanta dificuldade. :D
Hangout: Desenvolvimento de aplicações para Cloud Computing (Internet)
5 de Julho de 2013, 0:00 - sem comentários aindaHangout histórico esse que está por acontecer! Por que?
Nada em especial, depois de duas mudanças de data por conflito de agendas. Esse Hangout será sobre Desenvolvimento de aplicações para Cloud Computing com Bruno Domingues da Intel e está sendo organizado pelo [Meetup de Web Performance SP]. Na página do Meetup será postado o link com a transmissão.
Webinar: Como suportar um milhão de usuários simultâneos
2 de Julho de 2013, 0:00 - sem comentários aindaNa semana passada fui convidado pela Eventials para fazer uma apresentação sobre WebPerformance. A apresentação foi a mesma que fiz na Campus Party 2013 e no Latinoware 2012. Provavelmente essa apresentação irá virar um artigo mas enquanto isso não acontece vocês podem assistir cliquando aqui.
FISL só o 15 (2014)
1 de Julho de 2013, 0:00 - sem comentários aindaBem, bom… er…
FISL só em 2014, como diria alguém num passado não tão distante: às vezes precisamos “dar um passo para trás para dar dois à frente”. Eu gostaria muito de estar lá amanhã mas eu não posso viajar. Para que aqueles que irão desejo um bom evento e espero ano que vem nos reencontrarmos por lá. ;)
Debian no FISL14
20 de Junho de 2013, 0:00 - sem comentários aindaNeste FISL 14 temos muitas atividades Debian! :)
Atualmente são:
Bastidores Debian - Entenda como a distribuição Funciona - Eriberto
Oficina de criação de pacotes Debian - Loureiro
Oficina da Maratona de Empacotamento - fike
Integration of VistA Into Debian - Andreas Tille
Debian Med Project - Andreas Tille
GNUmed: Prontuário Eletrônico do Paciente do projeto Debian-Med Rogério Luz Coelho
Plenária Debian
Debian como seu desktop e colabore com o projeto - Albino
Debian Linux kernel tuning cargas extremas I/O ambiente corporativo, sgbd, email André Felipe Machado
Bastidores Debian - Entenda como a distribuição funciona Eriberto
Meu plano original era fazer a maratona de tradução no FISL mas como a oficina que foi aprovada foi de empacotamento, a maratona de tradução vai ser adiada um pouco. Mas é só um pouco. ;)
Então, pensando em como será a maratona de empacotamento (hackathon) Debian no FISL 14.
Pre-FISL
Objetivo do hackathon é ajudar o debian empacotando software que não estão empacotados no Debian, contribuir com pacotes existentes ou adotar um pacote órfão. Recomendação de leitura antes do FISL 14.
Texto do Terceiro ”Participando do projeto Debian - como começar”
Palestra do Eriberto ”Empacotamento de software no Debian GNU”
Se está você está começando agora, leia o que puder e procure um pacote ou um software para participar da maratona. Recomendo começar com um programa pequeno ou simples. Caso não tenha se identificado com algum time de empacotamento como o Terceiro comenta em seu texto, pode conversar comigo antes ou durante a maratona que posso ser o co-mantenedor ou fazer uma revisão antes de ser enviado por você para o Debian.
Existe muitos bugs nos pacotes que são fáceis de resolver: arquivo de licenças desatualizado, faltando página de manual, link quebrado do arquivo debian/watch, etc. Também no começo evite pacotes desenvolvidos em linguagens de programação que você não tem familiaridade, exceto se quiser aprendê-la.
Não precisa esperar a maratona, pode começar antes do evento. :)
Durante o FISL
Estarei a maior parte do FISL na área de grupo de usuários trabalhando nos pacotes, pode me procurar por lá. Também está nos planos raptar os desenvolvedores debian que estarão por lá para ajudar-nos com os possíveis pacotes NMU. Os NMUs a grosso modo acontecem quando sobe um pacote para o Debian em que o autor desta versão do pacote não é o “oficial”.
:)
O vinagre (2)
18 de Junho de 2013, 0:00 - sem comentários aindaHoje (17 de Junho de 2013) ainda está ocorrendo a manifestação contra aumento do transporte público (ônibus e metrô em São Paulo).
Segundo as notícias na internet, estima-se que tiveram um pouco mais de 200 mil participantes em todo Brasil. É um número significativo, tem uns 20 anos que não acontecia algo semelhante. Confesso, estou contente com a manifestação mas também preocupado.
Claramente a origem das manifestações com o Movimento do Passe Livre e conforme seus organizadores é um movimento apartidário mas não anti-partidário. Eles também se posicionam ideologicamente à esquerda. Nada contra, acho válido mas tanto para eles como os que consideram anti-partidários deverão tomar cuidado agora pois desde a última Sexta-feira (14/06/2013) a direita ou melhor, os setores mais raivosos e inteligentes se reposicionaram e pararam de atacar os protestos e movimentos que estavam/estão organizando e passaram a apoiá-los. E não foi só isso, estão disputando para transforma as manifestações contra o governos atuais.
Para ser ilustrativo, compare o comentário do Jabor antes (aqui e aqui) e depois (aqui). Não se atenha ao pedido de desculpa mas no restante do conteúdo, ouvirá que ele tenta direcionar para outras bandeiras. Isso é ruim?
Não! É parte da “democracia” atual e agora a disputa e direção das manifestações esta colocada. Então, meus poucos leitores (são bem poucos pelo as estatísticas de acesso) não sejam anti-partidários. Partido também é “estar de um lado (posição)” e o que não existe nessa manifestações é alguém sem um “Partido” e hoje o maior desafio para MPL será (caso consiga reverter o aumento da passagem) mostrar para onde irão ou se os protestos se generalização como foi a Primavera Árabe ou as manifestações na Turquia (Gerzi).
Recomendo assistir Krisis, documentário sobre a crise na Grécia em 2008 e os protestos contra o governo e a crise. Interessante assití-lo porque Athenas foi sede da Olimpíada de verão em 2004. ;)
Ah! Claro, Rauzito para trilha sonora.