471fdd4863910c2268ac03741809ab5e6517bd8b
[osm/devops.git] / tools / osm-report
1 #!/bin/bash
2
3 # OSM devops/tools - Tool that generates a report for debugging
4 #
5 # Copyright 2018 Telefonica
6 #
7 # Licensed under the Apache License, Version 2.0 (the "License");
8 # you may not use this file except in compliance with the License.
9 # You may obtain a copy of the License at
10 #
11 #   http://www.apache.org/licenses/LICENSE-2.0
12 #
13 # Unless required by applicable law or agreed to in writing, software
14 # distributed under the License is distributed on an "AS IS" BASIS,
15 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 # See the License for the specific language governing permissions and
17 # limitations under the License.
18
19 DIRNAME=$(readlink -f ${BASH_SOURCE[0]})
20 DIRNAME=$(dirname $DIRNAME)
21
22 #Get versions
23 echo "-------------------------------"
24 echo "Versions"
25 echo "-------------------------------"
26 echo "DIRNAME: $DIRNAME"
27 echo "docker version:"
28 docker version
29 echo "lxd version:"
30 lxd --version
31 echo "juju version:"
32 juju --version
33 echo "osm-devops deb package:"
34 dpkg -l |grep osm-devops
35 echo "osm-imdocs osm-im deb package:"
36 dpkg -l |grep osm-im
37 echo "python-osmclient deb package:"
38 dpkg -l |grep 
39 echo "whereis osm:"
40 whereis osm
41 echo "which osmclient:"
42 which osm
43 #dockers deb packages
44 echo "dockers deb packages"
45 for i in kafka keystone lcm light-ui mon mongo nbi pol prometheus ro mysql zookeeper; do
46     echo "docker osm_$i"
47     docker exec $(docker ps -q -f name=osm_$i -l) dpkg -l |grep osm
48 done
49 #dockers source code
50 echo "dockers deb packages"
51 echo "MON"
52 docker exec -it $(docker ps -aqf "name=osm_mon" -n 1) dpkg -l |egrep -i "osm|n2vc"
53 echo "POL"
54 docker exec -it $(docker ps -aqf "name=osm_pol" -n 1) dpkg -l |egrep -i "osm|n2vc"
55 echo "LCM"
56 docker exec -it $(docker ps -aqf "name=osm_lcm" -n 1) dpkg -l |egrep -i "osm|n2vc"
57 echo "NBI"
58 docker exec -it $(docker ps -aqf "name=osm_nbi" -n 1) dpkg -l |egrep -i "osm|n2vc"
59 echo "LW-UI"
60 docker exec -it $(docker ps -aqf "name=osm_light-ui" -n 1) dpkg -l |egrep -i "osm|n2vc"
61 echo "RO"
62 docker exec -it $(docker ps -aqf "name=osm_ro.1" -n 1) dpkg -l |egrep -i "osm|n2vc"
63 echo "OSMCLIENT"
64 dpkg -l |grep osmclient
65 echo "OSM-IM"
66 dpkg -l |grep osm-im
67 echo "OSM-DEVOPS"
68 dpkg -l |grep osm-devops
69
70 echo "docker osm_ro"
71 docker exec $(docker ps -q -f name=osm_ro -l) git -C /root/RO rev-parse HEAD
72 docker exec $(docker ps -q -f name=osm_ro -l) git -C /root/RO describe --tags --long --dirty
73 echo "docker osm_lcm"
74 docker exec $(docker ps -q -f name=osm_lcm -l) git -C /app rev-parse HEAD
75 docker exec $(docker ps -q -f name=osm_lcm -l) git -C /app describe --tags --long --dirty
76 echo "docker osm_nbi"
77 docker exec $(docker ps -q -f name=osm_nbi -l) git -C /app/NBI rev-parse HEAD
78 docker exec $(docker ps -q -f name=osm_nbi -l) git -C /app/NBI describe --tags --long --dirty
79 echo "docker osm_light-ui"
80 docker exec $(docker ps -q -f name=osm_light-ui -l) git -C /usr/share/osm-lightui rev-parse HEAD
81 docker exec $(docker ps -q -f name=osm_light-ui -l) git -C /usr/share/osm-lightui describe --tags --long --dirty
82 echo "docker osm_mon"
83 docker exec $(docker ps -q -f name=osm_mon -l) git -C /mon rev-parse HEAD
84 docker exec $(docker ps -q -f name=osm_mon -l) git -C /mon describe --tags --long --dirty
85 echo "docker osm_pol"
86 docker exec $(docker ps -q -f name=osm_pol -l) git -C /policy_module rev-parse HEAD
87 docker exec $(docker ps -q -f name=osm_pol -l) git -C /policy_module describe --tags --long --dirty
88
89 #Get configuration files
90 echo "-------------------------------"
91 echo "Configuration files"
92 echo "-------------------------------"
93 for i in $(find /etc/osm -type f -exec echo {} \;); do
94     [ -f "$i" ] || continue
95     echo "File $i:"
96     cat $i
97 done
98
99 #Get status of docker swarm
100 echo "-------------------------------"
101 echo "Docker swarm status"
102 echo "-------------------------------"
103 echo "Node ls:"
104 docker node ls
105 echo "Node inspect self:"
106 docker node inspect self --pretty
107 echo "Network inspect docker_gwbridge:"
108 docker network inspect docker_gwbridge
109 echo "Network inspect netOSM:"
110 docker network inspect netOSM
111 echo "Network inspect netosm:"
112 docker network inspect netosm
113
114 #Get status of dockers
115 echo "-------------------------------"
116 echo "Docker status"
117 echo "-------------------------------"
118 echo "-------------------------------"
119 echo "Docker stack ls"
120 echo "-------------------------------"
121 docker stack ls
122 echo "-------------------------------"
123 echo "Docker service ls"
124 echo "-------------------------------"
125 docker service ls
126 for i in $(docker stack ps |tail -n +2|awk '{print $1}'); do
127     echo "-------------------------------"
128     echo "Docker stack $i"
129     echo "-------------------------------"
130     docker stack ps $i
131 done
132
133 #Get log files
134 echo
135 echo "-------------------------------"
136 echo "Log files"
137 echo "-------------------------------"
138 echo "To be added"
139
140 #Get OSM general info
141 echo "-------------------------------"
142 echo "OSM info"
143 echo "-------------------------------"
144 for i in vim-list sdnc-list vnfd-list nsd-list ns-list vnf-list; do
145     echo "-------------------------------"
146     echo "OSM info: $i"
147     echo "-------------------------------"
148     osm $i
149 done
150
151 #Get OSM details
152 echo "-------------------------------"
153 echo "OSM details"
154 echo "-------------------------------"
155 for i in vim sdnc vnfd nsd ns; do
156     echo "-------------------------------"
157     echo "OSM details: $i"
158     echo "-------------------------------"
159     for j in $(osm $i-list|tail -n +4|awk '{print $4}'); do
160         echo "-------------------------------"
161         echo "OSM details: vim $j"
162         echo "-------------------------------"
163         osm $i-show $j
164     done
165 done
166 for i in vnf; do
167     echo "-------------------------------"
168     echo "OSM details: $i"
169     echo "-------------------------------"
170     for j in $(osm $i-list|tail -n +4|awk '{print $2}'); do
171         echo "-------------------------------"
172         echo "OSM details: vim $j"
173         echo "-------------------------------"
174         osm $i-show $j
175     done
176 done
177