Skip to content

Instantly share code, notes, and snippets.

@bicubic
Created December 30, 2015 03:40
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save bicubic/c0d79bd7b85c52580345 to your computer and use it in GitHub Desktop.
Save bicubic/c0d79bd7b85c52580345 to your computer and use it in GitHub Desktop.
{
"cells": [
{
"cell_type": "markdown",
"metadata": {},
"source": [
"<h1>Splunk Magic</h1>"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"<table class=\"nb_heading\">\n",
"<tr>\n",
"<td>\n",
" Project: Savvi @ NBN<br/>\n",
" Written: 12/12/2015<br/>\n",
" Author: Serge Rogov<br/>\n",
" Security: <span class=\"nb_sec nb_public\">Public</span><br/>\n",
"</td>\n",
"<td style=\"width: 50%\">\n",
" \n",
" <div class=\"savvi-logo\" style=\"height: 4em; background-position: right 0px\"></div>\n",
"</td>\n",
"</tr>\n",
"</table>"
]
},
{
"cell_type": "code",
"execution_count": 1,
"metadata": {
"collapsed": false
},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"Populating the interactive namespace from numpy and matplotlib\n"
]
}
],
"source": [
"%pylab inline"
]
},
{
"cell_type": "code",
"execution_count": 2,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/html": [
"<style>\n",
".nb_heading{\n",
"width: 100%;\n",
"border: 0 !important;\n",
"text-align: left;\n",
"}\n",
"\n",
".nb_heading tr{\n",
"border: none;\n",
"margin: 0;\n",
"padding: 0;\n",
"}\n",
"\n",
".nb_heading td{\n",
"border: none;\n",
"margin: 0;\n",
"padding: 0;\n",
"}\n",
"\n",
".nb_sec{\n",
"border-radius: 0.2em;\n",
"padding: 0.2em;\n",
"}\n",
"\n",
".nb_internal{\n",
"background-color: red;\n",
"color: white;\n",
"}\n",
"\n",
".nb_confidential{\n",
"background-color: red;\n",
"color: white;\n",
"}\n",
"\n",
".nb_public{\n",
"background-color: hsl(111, 87%, 55%);\n",
"}\n",
"\n",
" \n",
".nb_message{\n",
" background-color: rgba(0, 24, 0, 0.05);\n",
" border-left: 0.3em solid gray;\n",
" border-radius: 0.15em;\n",
" padding: 0.2em;\n",
" padding-left: 0.3em;\n",
" margin-bottom: 0.2em;\n",
"}\n",
"\n",
".nb_message.nb_error{\n",
" background-color: rgba(255, 24, 77, 0.1);\n",
" border-left: 0.3em solid red;\n",
"}\n",
"\n",
".nb_message.nb_warning{\n",
" background-color: rgba(255, 184, 24, 0.2);\n",
" border-left: 0.3em solid orange !important;\n",
"}\n",
" \n",
".savvi-logo {\n",
" background: url(data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<svg width="584px" height="172px" viewBox="0 0 584 172" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:sketch="http://www.bohemiancoding.com/sketch/ns">
    <!-- Generator: Sketch 3.4 (15588) - http://www.bohemiancoding.com/sketch -->
    <title>savvi-logo</title>
    <desc>Created with Sketch.</desc>
    <defs>
        <path id="path-1" d="M0.06,0.402 L583.781,0.402 L583.781,172 L0.06,172"></path>
    </defs>
    <g id="Page-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd" sketch:type="MSPage">
        <g id="savvi-logo" sketch:type="MSLayerGroup">
            <path d="M509.057,118.918 C505.331,114.205 505.332,107.572 509.058,102.86 L490.961,84.762 C489.419,85.981 487.66,86.757 485.836,87.186 L485.836,134.592 C487.659,135.021 489.419,135.796 490.96,137.015 L509.057,118.918" id="Fill-1" fill="#DF5E31" sketch:type="MSShapeGroup"></path>
            <path d="M490.26,157.912 C489.533,158.409 488.759,158.793 487.969,159.125 C489.301,161.778 491.198,164.09 493.514,165.906 L495.476,165.183 L490.26,157.912" id="Fill-2" fill="#C2412D" sketch:type="MSShapeGroup"></path>
            <path d="M537.221,64.439 C542.329,60.399 549.735,60.68 554.452,65.398 C559.17,70.115 559.451,77.521 555.411,82.63 L573.509,100.727 C576.484,98.375 580.232,97.534 583.781,98.135 L583.781,71.6 C583.781,60.559 574.83,51.608 563.789,51.608 L524.39,51.608 L537.221,64.439" id="Fill-3" fill="#EB942D" sketch:type="MSShapeGroup"></path>
            <path d="M532.346,93.106 L527.016,100.537 C527.497,100.899 527.985,101.248 528.423,101.686 C533.505,106.769 533.505,115.009 528.423,120.092 C527.985,120.529 527.497,120.878 527.017,121.24 L532.346,128.67 L569.267,115.082 C568.341,112.36 568.341,109.416 569.268,106.694 L532.346,93.106" id="Fill-4" fill="#DF5E31" sketch:type="MSShapeGroup"></path>
            <path d="M526.547,100.154 L531.757,92.89 L495.03,79.374 C494.573,80.534 493.896,81.614 493.093,82.63 L511.191,100.727 C515.667,97.188 521.891,96.97 526.547,100.154" id="Fill-5" fill="#E77933" sketch:type="MSShapeGroup"></path>
            <path d="M533.151,69.827 C533.608,68.666 534.285,67.587 535.088,66.571 L520.125,51.608 L499.797,51.608 L496.424,56.311 L533.151,69.827" id="Fill-6" fill="#EB942D" sketch:type="MSShapeGroup"></path>
            <path d="M531.757,128.887 L526.547,121.624 C521.891,124.808 515.666,124.59 511.19,121.05 L493.093,139.147 C493.896,140.163 494.573,141.243 495.03,142.403 L531.757,128.887" id="Fill-7" fill="#D8492C" sketch:type="MSShapeGroup"></path>
            <path d="M490.729,64.25 C491.209,64.612 491.697,64.96 492.134,65.398 C495.761,69.024 496.751,74.247 495.202,78.794 L532.122,92.381 L537.452,84.951 C536.972,84.589 536.484,84.241 536.047,83.804 C532.42,80.177 531.43,74.954 532.979,70.406 L496.059,56.819 L490.729,64.25" id="Fill-8" fill="#EB942D" sketch:type="MSShapeGroup"></path>
            <path d="M553.279,84.762 C548.802,88.302 542.577,88.52 537.921,85.335 L532.711,92.598 L569.44,106.115 C569.897,104.954 570.573,103.875 571.377,102.859 L553.279,84.762" id="Fill-9" fill="#E77933" sketch:type="MSShapeGroup"></path>
            <path d="M553.279,137.016 L571.376,118.918 C570.573,117.902 569.896,116.822 569.439,115.662 L532.711,129.179 L537.922,136.443 C542.578,133.258 548.802,133.476 553.279,137.016" id="Fill-10" fill="#D8492C" sketch:type="MSShapeGroup"></path>
            <path d="M495.835,56.094 L499.053,51.608 L485.836,51.608 L485.836,52.415 L495.835,56.094" id="Fill-11" fill="#EB942D" sketch:type="MSShapeGroup"></path>
            <path d="M573.508,121.05 L555.411,139.148 C559.451,144.256 559.17,151.663 554.452,156.38 C549.735,161.098 542.329,161.378 537.22,157.339 L524.39,170.17 L563.789,170.17 C574.83,170.17 583.781,161.219 583.781,150.178 L583.781,123.643 C580.232,124.244 576.483,123.403 573.508,121.05" id="Fill-12" fill="#C2412D" sketch:type="MSShapeGroup"></path>
            <path d="M485.836,61.976 C487.388,62.327 488.894,62.932 490.26,63.866 L495.47,56.602 L485.836,53.057 L485.836,61.976" id="Fill-13" fill="#EB942D" sketch:type="MSShapeGroup"></path>
            <path d="M537.452,136.826 L532.122,129.396 L495.202,142.983 C496.751,147.531 495.761,152.753 492.134,156.38 C491.697,156.818 491.209,157.166 490.729,157.528 L496.065,164.966 L532.98,151.373 C531.43,146.825 532.419,141.602 536.047,137.974 C536.484,137.537 536.972,137.188 537.452,136.826" id="Fill-14" fill="#C2412D" sketch:type="MSShapeGroup"></path>
            <path d="M495.84,165.692 L494.09,166.336 C495.26,167.188 496.518,167.925 497.862,168.51 L495.84,165.692" id="Fill-15" fill="#C2412D" sketch:type="MSShapeGroup"></path>
            <path d="M533.151,151.953 L496.429,165.475 L498.893,168.909 C501.056,169.71 503.386,170.17 505.828,170.17 L520.125,170.17 L535.088,155.207 C534.285,154.191 533.608,153.112 533.151,151.953" id="Fill-16" fill="#C2412D" sketch:type="MSShapeGroup"></path>
            <path d="M308.22,81.347 L318.439,51.943 C316.434,51.108 313.928,50.356 310.92,49.686 C307.913,49.02 304.736,48.684 301.395,48.684 C300.73,48.684 300.099,48.719 299.469,48.755 C298.675,48.968 297.842,48.669 297.075,48.98" id="Fill-17" fill="#0A0A08" sketch:type="MSShapeGroup"></path>
            <g id="Group-21">
                <mask id="mask-2" sketch:name="Clip 19" fill="white">
                    <use xlink:href="#path-1"></use>
                </mask>
                <g id="Clip-19"></g>
                <path d="M292.823,51.025 L292.514,50.141 C289.945,51.143 287.888,52.658 286.357,54.699 C283.35,58.709 280.843,64.309 278.839,71.493 L259.79,136.909 L241.743,72.244 C240.741,68.735 239.694,65.521 238.61,62.594 C237.521,59.673 236.103,57.206 234.349,55.2 C232.595,53.195 230.422,51.609 227.833,50.438 C225.24,49.271 221.943,48.684 217.932,48.684 C211.247,48.684 205.232,49.772 199.886,51.943 L241.242,169.493 L277.584,169.493 L305.812,88.275 L292.823,51.025" id="Fill-18" fill="#0A0A08" sketch:type="MSShapeGroup" mask="url(#mask-2)"></path>
                <path d="M91.734,63.472 C91.734,65.979 90.94,68.947 89.353,72.369 C87.764,75.797 86.053,79.011 84.216,82.019 C82.711,80.852 80.707,79.512 78.201,78.009 C75.694,76.505 72.936,75.126 69.93,73.874 C66.921,72.621 63.745,71.579 60.405,70.741 C57.06,69.906 53.802,69.487 50.63,69.487 C48.789,69.487 46.87,69.613 44.866,69.863 C42.86,70.114 41.063,70.615 39.476,71.367 C37.887,72.118 36.551,73.208 35.466,74.625 C34.378,76.047 33.836,77.927 33.836,80.265 C33.836,85.947 39.935,90.126 52.133,92.796 C57.146,93.799 62.116,95.096 67.047,96.681 C71.974,98.272 76.403,100.484 80.33,103.323 C84.255,106.167 87.43,109.758 89.855,114.102 C92.276,118.449 93.49,123.877 93.49,130.393 C93.49,137.078 92.193,143.011 89.604,148.189 C87.012,153.369 83.464,157.713 78.953,161.223 C74.441,164.73 69.135,167.405 63.037,169.242 C56.936,171.079 50.294,172 43.11,172 C35.592,172 29.325,171.456 24.312,170.37 C19.299,169.282 15.121,167.989 11.781,166.486 C9.438,165.482 6.893,164.022 4.137,162.099 C1.379,160.18 0,157.549 0,154.204 C0,151.365 0.835,148.399 2.507,145.307 C4.175,142.215 6.098,139.001 8.272,135.656 C9.775,136.995 11.655,138.374 13.911,139.791 C16.167,141.213 18.755,142.549 21.68,143.802 C24.603,145.055 27.736,146.101 31.08,146.934 C34.421,147.774 37.847,148.189 41.356,148.189 C43.525,148.189 45.782,148.024 48.123,147.688 C50.461,147.354 52.51,146.684 54.264,145.682 C56.018,144.679 57.48,143.344 58.65,141.671 C59.818,140.003 60.405,137.83 60.405,135.155 C60.405,130.31 58.525,126.845 54.765,124.753 C51.005,122.665 45.367,120.868 37.847,119.365 C32.999,118.361 28.323,117.027 23.811,115.355 C19.299,113.687 15.29,111.47 11.781,108.712 C8.272,105.955 5.471,102.49 3.385,98.31 C1.293,94.137 0.251,89.036 0.251,83.021 C0.251,77.006 1.586,71.743 4.261,67.231 C6.933,62.72 10.485,58.878 14.914,55.703 C19.339,52.53 24.477,50.149 30.329,48.559 C36.175,46.973 42.273,46.178 48.624,46.178 C55.306,46.178 61.283,46.679 66.546,47.682 C71.81,48.684 76.36,50.023 80.206,51.692 C87.556,54.699 91.398,58.628 91.734,63.472" id="Fill-20" fill="#0A0A08" sketch:type="MSShapeGroup" mask="url(#mask-2)"></path>
            </g>
            <path d="M171.376,110.091 L167.866,110.091 C166.695,110.091 165.524,110.177 164.357,110.342 C160.179,110.678 156.044,111.218 151.95,111.971 C147.854,112.723 144.22,113.894 141.049,115.479 C137.871,117.07 135.283,119.201 133.278,121.871 C131.274,124.545 130.27,127.973 130.27,132.147 C130.27,136.827 131.606,140.795 134.281,144.052 C136.952,147.311 141.464,148.94 147.815,148.94 C150.987,148.94 153.995,148.525 156.839,147.688 C159.678,146.853 162.184,145.768 164.357,144.429 C166.528,143.093 168.243,141.633 169.496,140.042 C170.749,138.457 171.376,136.995 171.376,135.656 L171.376,110.091 L171.376,110.091 Z M203.457,139.166 C203.457,152.198 205.377,161.81 209.223,167.989 C206.215,169.156 203.414,169.994 200.825,170.495 C198.234,170.997 195.519,171.248 192.68,171.248 C186.665,171.248 182.11,170.077 179.02,167.739 C175.926,165.401 173.964,162.06 173.13,157.713 C169.453,161.559 164.608,164.816 158.593,167.488 C152.578,170.158 145.222,171.499 136.537,171.499 C132.025,171.499 127.514,170.871 123.002,169.619 C118.491,168.366 114.394,166.321 110.72,163.478 C107.043,160.638 104.035,156.835 101.697,152.073 C99.356,147.311 98.189,141.507 98.189,134.654 C98.189,126.132 100.233,119.201 104.329,113.851 C108.422,108.505 113.559,104.287 119.743,101.193 C125.923,98.103 132.608,95.972 139.794,94.802 C146.978,93.634 153.58,92.882 159.595,92.546 C161.601,92.381 163.562,92.295 165.485,92.295 L170.875,92.295 L170.875,87.784 C170.875,81.435 169.159,76.923 165.736,74.249 C162.31,71.579 156.753,70.24 149.068,70.24 C141.882,70.24 135.49,71.41 129.895,73.748 C124.294,76.09 118.823,78.76 113.478,81.769 C111.135,78.929 109.255,75.797 107.838,72.369 C106.416,68.947 105.707,66.397 105.707,64.724 C105.707,62.555 107,60.339 109.593,58.084 C112.182,55.827 115.733,53.823 120.244,52.067 C124.756,50.313 129.933,48.896 135.784,47.806 C141.631,46.722 147.815,46.178 154.332,46.178 C163.355,46.178 170.999,47.097 177.266,48.934 C183.532,50.776 188.626,53.615 192.555,57.457 C196.478,61.302 199.279,66.103 200.951,71.868 C202.619,77.634 203.457,84.362 203.457,92.045 L203.457,139.166 L203.457,139.166 Z" id="Fill-22" fill="#0A0A08" sketch:type="MSShapeGroup"></path>
            <path d="M455.414,18.699 C455.414,24.048 453.617,28.392 450.026,31.733 C446.431,35.078 442.131,36.746 437.118,36.746 C431.937,36.746 427.594,35.078 424.085,31.733 C420.575,28.392 418.821,24.048 418.821,18.699 C418.821,13.353 420.575,8.967 424.085,5.541 C427.594,2.117 431.937,0.402 437.118,0.402 C442.131,0.402 446.431,2.117 450.026,5.541 C453.617,8.967 455.414,13.353 455.414,18.699" id="Fill-23" fill="#0A0A08" sketch:type="MSShapeGroup"></path>
            <path d="M455.164,169.743 C454.495,170.077 452.99,170.327 450.652,170.495 C448.311,170.659 445.804,170.747 443.133,170.747 C436.617,170.747 431.31,169.368 427.217,166.61 C423.121,163.854 421.076,158.3 421.076,149.943 L421.076,49.686 C421.41,49.522 422.746,49.311 425.087,49.06 C427.425,48.81 429.932,48.684 432.607,48.684 C435.277,48.684 437.952,48.934 440.626,49.436 C443.298,49.937 445.722,50.9 447.896,52.318 C450.065,53.74 451.82,55.746 453.159,58.334 C454.495,60.926 455.164,64.309 455.164,68.484 L455.164,169.743" id="Fill-24" fill="#0A0A08" sketch:type="MSShapeGroup"></path>
            <path d="M297.06,48.987 C305.647,45.589 317.166,46.645 325.548,50.438 C328.137,51.609 330.31,53.195 332.064,55.2 C333.818,57.206 335.235,59.673 336.325,62.594 C337.409,65.521 338.456,68.735 339.458,72.244 L357.505,136.909 L376.553,71.493 C378.558,64.309 381.065,58.709 384.072,54.699 C387.08,50.69 392.093,48.684 399.11,48.684 C402.45,48.684 405.628,49.02 408.634,49.686 C411.643,50.356 414.148,51.108 416.154,51.943 L375.299,169.493 L338.957,169.493 C336.796,163.295 334.635,157.098 332.474,150.901 C327.713,137.248 322.952,123.596 318.192,109.943 C313.406,96.219 308.62,82.495 303.835,68.771" id="Fill-25" fill="#0A0A08" sketch:type="MSShapeGroup"></path>
        </g>
    </g>
</svg>)\n",
" no-repeat\n",
" left center;\n",
" background-size: contain;\n",
"} \n",
"\n",
"</style>"
],
"text/plain": [
"<IPython.core.display.HTML object>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"import pandas as pd\n",
"import time\n",
"import io\n",
"import httplib2\n",
"from IPython.display import display, HTML \n",
"import splunklib.results as results\n",
"import splunklib.client\n",
"import json\n",
"import IPython.display\n",
"from IPython.core.magic import (register_line_magic, \n",
" register_cell_magic)\n",
"import qgrid2 as qgrid\n",
"\n",
"\n",
"plt.style.use('ggplot')\n",
"with open('custom_html.html', 'r') as f:\n",
" custom_html = f.read()\n",
"display(HTML(custom_html))"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"from splunk_nb import *\n",
"if sys.version_info[0] < 3:\n",
" from StringIO import StringIO\n",
"else:\n",
" from io import StringIO"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"with open('splunk-auth-yong', 'r') as f:\n",
" #TODO SR: encrypt splunk auth? \n",
" splunk_auth = json.loads(f.read())"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"service = splunklib.client.connect(autologin=True, **splunk_auth) #app=\"apm_snpm\","
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"def replace_splunk_time(df):\n",
" '''Converts `nb_epoch` into `_time` as datetime64\n",
" `nb_epoch=_time` must be supplied by the query\n",
"\n",
" '''\n",
" if ('nb_epoch' not in df.columns):\n",
" return\n",
" \n",
" df['_time'] = pd.to_numeric(df['nb_epoch'], errors='coerce').astype('datetime64[s]')\n",
" df.drop('nb_epoch', 1, inplace=True)\n",
"\n",
"class SplunkQuery:\n",
" job = None\n",
" search_string = None\n",
" def __init__(self, search_string):\n",
" if not search_string.startswith('search '):\n",
" search_string = 'search ' + search_string + ' | eval nb_epoch=_time | fields - _time'\n",
" self.search_string = search_string\n",
" \n",
" def _dispatch_query(self):\n",
" self.job = service.jobs.create(self.search_string, **{\"exec_mode\": \"normal\", \n",
" \"earliest_time\": '-10y', \n",
" \"latest_time\": '-0min',\n",
" \"output_mode\": \"csv\",\n",
" \"preview\": True,\n",
" \"maxEvents\": 0})\n",
" \n",
" def _await(self):\n",
" while True:\n",
" self.job.refresh()\n",
" if self.job[\"isDone\"] == \"1\":\n",
" break\n",
" time.sleep(1)\n",
" \n",
" def _report_progress(self):\n",
" #publish progress (stdout, NB)\n",
" pass\n",
" \n",
" def _await_with_progress(self):\n",
" print \"waiting\"\n",
" while True:\n",
" self.job.refresh()\n",
" if self.job[\"isDone\"] == \"1\":\n",
" break\n",
" time.sleep(1)\n",
" print \"done\"\n",
" \n",
" def _df_postprocess(self, df):\n",
" replace_splunk_time(df)\n",
" return df\n",
" \n",
" def _get_results_legacy(self):\n",
" \"\"\"Fetches one page of results using the offically recommended\n",
" approach. This method is SLOW.\n",
" \n",
" Args:\n",
" offset: start offset\n",
" count: number of results to return\n",
" \"\"\"\n",
" job = self.job\n",
" resultCount = job[\"resultCount\"] # Number of results this job returned\n",
" offset = 0; # Start at result 0\n",
" count = 100; # Get sets of 10 results at a time\n",
" items = []\n",
" \n",
" while (offset < int(resultCount)):\n",
" kwargs_paginate = {\"count\": count,\n",
" \"offset\": offset}\n",
" # Get the search results and display them\n",
" blocksearch_results = job.preview(output_mode=\"csv\", **kwargs_paginate)\n",
"\n",
" for result in results.ResultsReader(blocksearch_results):\n",
" items.append(result)\n",
" offset += count\n",
" df = pd.DataFrame(items)\n",
" df = self._df_postprocess(df)\n",
" return df\n",
" \n",
" def get_preview(self):\n",
" self.job.refresh()\n",
" buf = StringIO()\n",
" job = self.job\n",
" self.buf=buf\n",
" \n",
" if (self.job['dispatchState']=='PARSING'):\n",
" return None #haven't received a resultPreviewCount yet TODO: backport to other cases\n",
" resultCount = int(self.job['resultPreviewCount'])\n",
" if (resultCount==0):\n",
" return None #no preview yet\n",
" \n",
" offset = 0\n",
" page_count = 1000\n",
" \n",
" while (offset < resultCount):\n",
" kwargs_paginate = {\"count\": page_count,\n",
" \"offset\": offset}\n",
" \n",
" searchresults = job.preview(output_mode=\"csv\", **kwargs_paginate).read() \n",
" \n",
" #suppress the CSV header on pages other than the first\n",
" if (offset == 0):\n",
" buf.write(searchresults)\n",
" else:\n",
" buf.write(searchresults[searchresults.find('\\n'):])\n",
" offset+=page_count\n",
" \n",
" buf.seek(0)\n",
" \n",
" df = pd.read_csv(buf)\n",
" df = self._df_postprocess(df)\n",
" return df\n",
" \n",
" def display_messages(self):\n",
" classes = {'info': 'nb_info', 'fatal': 'nb_error', 'error': 'nb_error'}\n",
" html = ''\n",
" for k, v in self.job.messages.iteritems():\n",
" line = '<div class=\"nb_message {classname}\">{message}</div>'.format(classname=classes[k], message=v[0])\n",
" html = html + line\n",
" display(HTML(html))\n",
" \n",
" def _get_results_page_fast(self, offset, count):\n",
" \"\"\"Fetches one page of results\n",
" \n",
" Args:\n",
" offset: start offset\n",
" count: number of results to return\n",
" \"\"\"\n",
" #TODO: uses `service` which is in global scope. Refactor\n",
" buf = StringIO()\n",
" self.buf=buf\n",
" sid = self.job['sid']\n",
" myhttp = httplib2.Http(disable_ssl_certificate_validation=True)\n",
" myhttp.add_credentials(service.username, service.password)\n",
" url = '/services/search/jobs/{0}/results?output_mode=csv&&offset={1}&count={2}'.format(sid, offset, count)\n",
" baseurl = str(service.authority)\n",
" searchresults = myhttp.request(baseurl + url, 'GET')[1] \n",
" buf.write(searchresults)\n",
" \n",
" buf.seek(0)\n",
" df = pd.read_csv(buf)\n",
" df = self._df_postprocess(df)\n",
" return df\n",
" \n",
" def _get_results_fast_full(self, page_count=50000):\n",
" \"\"\"Fetches entire result set quickly\n",
" \n",
" Args:\n",
" offset: start offset\n",
" page_count: maximum number of results per page (default splunk limit is 50k)\n",
" \n",
" Notes:\n",
" Not sure which Splunk setting dictates maximum number of\n",
" results returned (page count). Ideally should identify it\n",
" and dynamically read via SDK\n",
" \"\"\"\n",
" #TODO: uses `service` which is in global scope. Refactor\n",
" buf = StringIO()\n",
" self.buf=buf\n",
" sid = self.job['sid']\n",
" resultCount = int(self.job['resultCount'])\n",
" \n",
" myhttp = httplib2.Http(disable_ssl_certificate_validation=True)\n",
" myhttp.add_credentials(service.username, service.password)\n",
" \n",
" offset = 0\n",
" \n",
" while (offset < resultCount):\n",
" url = '/services/search/jobs/{0}/results?output_mode=csv&&offset={1}&count={2}'.format(\n",
" sid, offset, page_count)\n",
" \n",
" baseurl = str(service.authority)\n",
" searchresults = myhttp.request(baseurl + url, 'GET')[1] \n",
" \n",
" #suppress the CSV header on pages other than the first\n",
" if (offset == 0):\n",
" buf.write(searchresults)\n",
" else:\n",
" buf.write(searchresults[searchresults.find('\\n'):])\n",
" offset+=page_count\n",
" \n",
" buf.seek(0)\n",
" df = pd.read_csv(buf)\n",
" df = self._df_postprocess(df)\n",
" return df\n",
" \n",
" \n",
" \n",
" def execute(self, **kwargs):\n",
" \"\"\"Executes the query\n",
" \n",
" Args:\n",
" TODO: add args\n",
" \"\"\"\n",
" self._dispatch_query()\n",
" #self._await_with_progress()\n",
" return\n",
" "
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"collapsed": true
},
"outputs": [],
"source": [
"def run_blocking(query):\n",
" global last_job\n",
" x = SplunkQuery(query)\n",
" last_job = x\n",
" x.execute()\n",
" x._await()\n",
" return x._get_results_fast_full()"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"collapsed": true
},
"outputs": [],
"source": [
"def preview_kernel(df):\n",
" chart=df.set_index('_time')['count'].astype('float')\n",
" plt.gca().cla() \n",
" chart.plot()\n",
" IPython.display.clear_output(wait=True)\n",
" IPython.display.display(plt.gcf()) "
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"collapsed": true
},
"outputs": [],
"source": [
"def run_preview(query):\n",
" global last_job\n",
" x = SplunkQuery(query)\n",
" last_job = x\n",
" x.execute()\n",
" while(x.job.is_done() == False):\n",
" \n",
" d = x.get_preview()\n",
" if (d is None):\n",
" IPython.display.clear_output(wait=True)\n",
" print \"waiting\"\n",
" sys.stdout.flush()\n",
" continue\n",
" \n",
" preview_kernel(d)\n",
" \n",
" time.sleep(1.0)\n",
" \n",
" IPython.display.clear_output(wait=True)\n",
" x.display_messages()\n",
" print \"Done!\"\n",
" return x"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"def run_preview(query):\n",
" global last_job\n",
" x = SplunkQuery(query)\n",
" last_job = x\n",
" first_results = True\n",
" x.execute()\n",
" while(x.job.is_done() == False):\n",
" \n",
" d = x.get_preview()\n",
" if (d is None):\n",
" IPython.display.clear_output(wait=True)\n",
" print x.job['dispatchState']\n",
" sys.stdout.flush()\n",
" time.sleep(1.0)\n",
" continue\n",
" else:\n",
" if (first_results):\n",
" grid = qgrid.QGridWidget(df=d)\n",
" display(grid)\n",
" first_results = False\n",
" \n",
" grid.df = d\n",
" \n",
" #preview_kernel(d)\n",
" \n",
" time.sleep(1.0)\n",
" \n",
" IPython.display.clear_output(wait=False)\n",
" x.display_messages()\n",
" print \"Done!\"\n",
" return x\n"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"@register_cell_magic\n",
"def splunk(line, cell):\n",
" query = cell\n",
" if('preview=True' in line):\n",
" run_preview(query)\n",
" else:\n",
" return run_blocking(query)\n",
" \n",
" "
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"x = run_preview('source=\"megadump_60.tgz:*\" earliest=\"11/30/2015:20:00:00\" | timechart span=4h avg(max_latency) as count')"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"<br/>\n",
"<br/>\n",
"<br/>\n",
"<br/>\n",
"<br/>\n",
"<br/>\n",
"<br/>\n",
"<br/>\n",
"<br/>\n",
"<br/>\n",
"<br/>\n",
"<br/>\n",
"<br/>\n",
"<br/>\n",
"<br/>\n",
"<br/>\n",
"<br/>\n",
"<br/>\n",
"<br/>\n",
"<br/>"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"%%splunk preview=True\n",
"source=\"megadump_60.tgz:*\" earliest=\"12/04/2015:20:00:00\" | timechart span=4h avg(max_latency) as count"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"collapsed": false
},
"outputs": [],
"source": [
"df=last_job._get_results_fast_full()\n",
"df.set_index('_time')['count'].plot()"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"collapsed": true
},
"outputs": [],
"source": []
}
],
"metadata": {
"kernelspec": {
"display_name": "Python 2",
"language": "python",
"name": "python2"
},
"language_info": {
"codemirror_mode": {
"name": "ipython",
"version": 2
},
"file_extension": ".py",
"mimetype": "text/x-python",
"name": "python",
"nbconvert_exporter": "python",
"pygments_lexer": "ipython2",
"version": "2.7.11"
}
},
"nbformat": 4,
"nbformat_minor": 0
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment