This article is written in English and Portuguese
Este artigo está escrito em Inglês e Português
English version:
Some time ago, during a customer engagement, I felt the need to be able to show them if there were lock waiting sessions in their most busy system. Of course any old time Informix DBA will tell that onstat -k/K is able to provide this. But in their environment they needed this to be available to a broader audience than just the DBA team (who are the ones with database server command line access). So we decided to create a simple PHP script with Informix connection that showed it in a web page available in their Intranet. They're currently moving into using Open Admin Tool (OAT) and I though it would be nice to move that into OAT. Note that OAT already includes some reports that provide similar (although with less detail) information (session waiting report).
So I thought it would be nice to do it properly and create a plug-in. I searched around, specifically in OAT's home (
http://www.openadmintool.org ) and found a link to an article about creating plugins in OAT:
http://www.ibm.com/developerworks/db2/library/techarticle/dm-0808vonbargen/The author of this article is Erika Von Bargen, an IBM colleague, which is very active in the OAT specific IIUG mailing list. People who went to this year's IIUG conference possibly also know her since she was there presenting sessions about OAT.
Now... To tell you the complete truth, sometimes I'm very lazy (aren't we all at times?) when it comes to properly read documentation. So I just jumped into a terminal and started looking at an example plug-in provided with OAT. In a few minutes I had changed the query and I was seeing the information we were used to see in the customized web page. Obviously every message and column header was missing, the menus were wrong etc. But It was enough to become enthusiastic about this subject. I posted a few messages in OAT's mailing list, and had a quick feedback from Erika, which was a great help.
After the initial startup I decided to do it properly, and I read the article above, and it's a nice, clear and concise article. It's perfect to get you started.
So, after the initial "code, test, fix error, test....", instead of the "read, plan, code, test, fix..." I was ready to do it properly and I took some time at home to play with this. And I kept adding some features, some usability details and finally got to a point where I think I have a working plug-in. It has four options:
- List all the instance locks
This shows information similar to onstat -K, but most of the information is immediately readable (meaning you don't have to query sysmaster to get the table names, and you don't have to run onstat -u | grep .... to get the session number. - List locks with waiters
This shows information on every lock that has a lock list. The information includes:
- The owner username, session number, process id and client machine
- The waiter username, session number, process id and client machine
- The table/index in question, the time the lock was established and how long the wait is waiting
- List locks per table
This shows information about locking for every active table in your system. The information includes the number of currently held locks, the number of lock requests made on the table, the number of lock waits, the number of deadlocks and the number of lock timeouts
- List locks per session
This shows the number of currently held locks, the number of lock requests made by the session, the number of lock waits, the number of deadlocks and the number of lock timeouts
One of the great things about OAT is how easy we can localize our plug-ins. In this case, due to my linguistic limitations, I've only included the standard English messages and naturally the Portuguese ones. I'd be glad to add more, if people who can write in other languages (already used by OAT) could send me the translated messages. The number of words/phrases to translate is really short and to be honest I'm tempted to give some online translation a try... But I would prefer some user contributions, in case you find the plug-in useful....
Also, I'd love to receive feedback about bugs or improvements. I have a few ones on my mind, but it's always better to listen to others...
So, where is it? I've just upload it to IIUG software repository. It's the first time I do it, so I'm not sure how long will it take to become available
[UPDATE 31 Aug 2010]: It's already available on the IIUG repository .
If you want to check the aspect of it, before giving it a try, please see below some snapshots.
How stable is it? It wasn't tested on big systems. But all it does is query the sysmaster. So, the worst thing that could happen would be giving you some wrong information. It should not do any harm to your system. In any case treat this as a beta release for now. One thing that can happen is that the pages show all the information fetched by the queries. In large systems, with thousands of locks, sessions, or tables, this can translate into very big HTML pages... Be aware of this.
To the best of my knowledge the queries return proper results. The locks with waiters page is based on a query being used for a fairly long time. The other queries were created and tested in a very controlled environment, so admittedly it's possible that they don't cover some situations.
Every feedback is welcome. Although OAT already includes some functionality in this area, I think this will give you a more direct and condensed tool to monitor your database locking activity. As such I believe the plug-in can be useful and it certainly can be improved.
VersĂŁo portuguesa:
Há algum tempo atrás, durante um trabalho num cliente, senti a necessidade de lhes mostrar se tinham sessões Ă espera de locks no sistema mais utilizado. Claro que qualquer DBA Informix com alguma experiĂŞncia dirá que o onstat -k/K Ă© capaz de responder a esta necessidade. Mas no caso que refiro, era necessário que esta informação estivesse disponĂvel para uma audiĂŞncia mais alargada que apenas a equipa de DBAs (os Ăşnicos com acesso Ă linha de comando no servidor de base de dados).
Por isso, decidimos criar um
script PHP, simples, com conexão ao Informix, que mostrasse a informação numa página
Web disponĂvel na Intranet da empresa. Actualmente estĂŁo a começar a usar o Open Admin Tool (OAT) e pareceu-me adequado colocar esta funcionalidade dentro da mesma ferramenta. Note-se que o OAT já fornece informaçao semelhante (embora com menos detalhe) no relatĂłrio de sessões em espera.
Assim pensei que seria bom fazer isto como deve ser e criar um plug-in. Procurei informação, especificamente no
website do OAT (
http://www.openadmintool.org ) e encontrei uma ligação a um artigo sobre criação de plug-ins para o OAT:
http://www.ibm.com/developerworks/db2/library/techarticle/dm-0808vonbargen/A autora deste artigo Ă© a Erika Von Bargen, uma colega da IBM, bastante activa na
mailing list do OAT do IIUG. Quem teve oportunidade de estar na conferência do IIUG este ano também teve oportunidade de assistir a sessões apresentadas por ela, precisamente relacionadas com o OAT
Bom... Para ser franco, ocasionalmente sou bastante preguiçoso (não seremos todos de vez em quando?) quando toca a ler documentação. Por isso, abri uma sessão e comecei a estudar um exemplo de plug-in fornecido com o OAT. Em apenas alguns minutos, tinha mudado a
query que lhe serve de base e estava a ver a informação a que estávamos habituados na página personalizada. Naturalmente, todas as mensagens e cabeçalhos de tabelas estavam errados ou em falta, os menus estavam errados etc. Mas foi o suficiente para me tornar um entusiasta do assunto. Coloquei algumas mensagens na
mailing list do OAT e obtive respostas rápidas da Erika que foram uma grande ajuda.
Após o arranque inicial, decidi que devia fazer as coisas devidamente, e li o artigo mencionado acima, que é bom, claro e conciso. Ideal para quem quer começar com a tarefa de criar um plug-in.
Assim, apĂłs a abordagem inicial de "codificar, testar, corrigir erros, testar....", passei para a de "ler, planear, codificar, testar, corrigir....". Estava preparado para fazer isto como deve ser e disponibilizei algum tempo em casa para "brincar" com isto. E fui adicionando funcionalidades, detalhes para melhorar a usabilidade, e finalmente cheguei a um ponto onde julgo ter um plug-in que funciona.
Tem quatro opções:
- Listar os bloqueios na instância
Isto mostra informação semelhante ao onstat -K, mas a maioria da informação é de leitura imediata (ou seja, não é necessário pesquisar na sysmaster para obter os nomes das tabelas, e não temos de correr um onstat -u | grep ... para obter o número da sessão - Listar os bloqueios com fila de espera
Isto mostra informação de cada bloqueio que tenha uma lista de espera. Esta informação incluĂ:
- O dono do bloqueio, incluindo nome de utilizador, número de sessão, número de processo e a máquina cliente
- Quem está Ă espera, incluĂndo o nome de utilizador, nĂşmero de sessĂŁo, nĂşmero de processo e a máquina cliente
- A tabela/indĂce que tem o bloqueio, o instante em que o bloqueio foi estabelecido e há quanto tempo existe a espera - Listar os bloqueios por tabela
Isto mostra informação sobre os bloqueios para todas as tabelas activas do seu sistema.
A informação incluà o número de bloqueios activos no momento, o número de pedidos de bloqueios feitos sobre a tabela, o número de esperas por bloqueios sobre a tabela, o número de deadlocks que envolveram a tabela, e o número de vezes que os tempos de espera por bloqueios expiraram - Listar os bloqueios por sessão
Isto mostra o número de bloqueios que cada sessão mantém activos, o número de pedidos de bloqueio feitos pelas sessões, o número de esperas por bloqueios, o número de deadlocks da sessão, e o número de tempos de espera por bloqueios expirados
Uma das coisas boas do OAT Ă© a facilidade com que se pode
localizar ou traduzir os nossos plug-ins. Devido Ă s minhas limitações linguĂsticas, neste caso, o plug-in sĂł incluĂ as mensagens em IngĂŞs (
standard) e naturalmente em PortuguĂŞs. Gostaria de adicionar mais, caso quem escreva noutras lĂnguas (das já usadas pelo OAT) me queira enviar as mensagens traduzidas. O nĂşmero de palavras/frases a traduzir Ă© realmente pequeno, e para ser honesto sinto-me tentado a experimentar os tradutores automáticos
online. Mas seria preferĂvel se alguĂ©m contribuĂsse caso considere o plug-in Ăştil.
Adicionalmente, terei todo o gosto em receber comentários sobre
bugs ou melhorias. Tenho algumas em mente, mas é sempre melhor escutar opiniões de outros...
Então, onde está o plug-in? Acabei de fazer o envio para o repositório de
software do IIUG. É a primeira vez que o faço, e sinceramente nĂŁo sei quanto tempo levará a ficar disponĂvel.
[ACTUALIZAÇÂO 31 Aug 2010]: Já está disponĂvel no repositĂłrio de
software do IIUG.
Se desejar ver o aspecto do plug-in, antes de o testar, por favor veja as imagens abaixo.
QuĂŁo estável Ă© o plug-in? NĂŁo foi testado em sistemas grandes. Mas tudo o que faz Ă© pesquisar a sysmaster. Por isso, alĂ©m de alguma possĂvel informação errada nĂŁo deverá causar qualquer problema nos seus sistemas. Em todo o caso trate isto como uma
release beta por enquanto. Algo que pode acontecer é que as páginas mostram toda a informação obtida nas
queries. Em sistemas grandes, com milhares de bloqueios, sessões ou tabelas, isto pode traduzir-se em páginas HTML muito grandes.... Tenha algum cuidado com isso.
Tanto quanto me apercebi, as pesquisas retornam resultados correctos. A lista de bloqueios com lista de espera baseia-se numa
query que utilizo há bastante tempo. As outras pesquisas foram criadas e testadas num ambiente muito controlado, logo Ă© possĂvel que possam nĂŁo prever algumas situações.
Todo o
feedback será muito bem vindo. Apesar de o OAT já incluir alguma funcionalidade nesta área, julgo que este plug-in será uma ferramenta mais directa e condensada para monitorizar toda a actividade relacionada com bloqueios nas suas instâncias Informix. Como tal, acredito que o plug-in possa ser útil e certamente poderá ser melhorado.
Snapshots/Écrans:
Lock List
Lista de bloqueios
Lock waiters
Lista de bloqueios com fila de espera
Locks per table
Bloqueios por tabela
Locks per session
Bloqueios por sessĂŁo