Product
Socket Now Supports uv.lock Files
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
juttle-mysql-adapter
Advanced tools
MySQL adapter for the Juttle data flow language, with read & write support.
Read rows from your logs
SQL table where the log level
is info
, with the
default limit of 10000:
read mysql -table 'logs' level = 'info'
Perform an equivalent query using the raw
option:
read mysql -raw 'select * from "logs" where "level" = "info" limit 10000'
Add a debug
option to return the final SQL query instead (before any pagination):
read mysql -table 'logs' -debug true level = 'info'
will output: {query: 'select * from "logs" where "level" = 'info' limit 10000'}
.
If you have time series data in your table, indicate the column with the
timestamp using the timeField
option to paginate and sort data correctly:
read mysql -timeField 'create_time' -table 'logs';
read mysql -timeField 'create_time' -table 'logs -from :2 days ago: -to :1 hour ago:;
The content of the column indicated by timeField
will appear as the time
field in resulting points.
Like Juttle itself, the adapter is installed as a npm package. Both Juttle and the adapter need to be installed side-by-side:
$ npm install juttle
$ npm install juttle-mysql-adapter
The adapter needs to be registered and configured so that it can be used from
within Juttle. To do so, add the following to your ~/.juttle/config.json
file:
{
"adapters": {
"mysql": {
"connection": {
"user": "root",
"password": "password",
"host": "localhost",
"database": "test"
}
}
}
}
The connection
key should point to your MySQL instance.
More documentation on the connection object can be found in the knex.js documentation
Name | Type | Required | Description |
---|---|---|---|
table | string | yes | table to query |
raw | string | no | send a raw SQL query to MySQL |
debug | boolean | no | output a query corresponding to current set of options and filters |
timeField | string | no | assume datetime column, to and from options will use this to limit rows by time |
fetchSize | integer | no | row limit, defaults to 10000 records |
from | moment | no | select points after this time (inclusive) |
to | moment | no | select points before this time (exclusive) |
Name | Type | Required | Description |
---|---|---|---|
table | string | yes | table to write points into |
Contributions are welcome! Please file an issue or open a pull request.
To check code style and run unit tests:
npm test
Both are run automatically by Travis.
When developing you may run into failures during linting where jscs complains
about your coding style and an easy way to fix those files is to simply run
jscs --fix test
or jscs --fix lib
from the root directory of the project.
After jscs fixes things you should proceed to check that those changes are
reasonable as auto-fixing may not produce the nicest of looking code.
0.3.0
Released 2016-02-08
FAQs
Juttle adapter for MySQL
The npm package juttle-mysql-adapter receives a total of 10 weekly downloads. As such, juttle-mysql-adapter popularity was classified as not popular.
We found that juttle-mysql-adapter demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 2 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.
Security News
PEP 770 proposes adding SBOM support to Python packages to improve transparency and catch hidden non-Python dependencies that security tools often miss.