We've been using highlight for our bootstrapped member management platform[1] and I gotta say I'm super impressed with the session replay feature, it's really helpful for understanding user behavior at a fraction of the price of competitors.
I remember wanting to use Heap's session replay only to release they want hundreds of dollars per _month_, my last bill with highlight was $2.38 I recall.
That's all to say that I'm glad Highlight is figuring out how to scale while still offering their features to the small players of the world.
Very nice and very inspirational for someone bootstrapping a startup.
The pages clearly defined what you are building and how to use it.
The explanation of platform fees makes sense, though it could more clear if the pricing examples are only based on those fees or are account limits to number of members or dues.
You might want to check your terms of service, they do not list a jurisdiction and have the placeholder [jurisdiction] instead.
clickhouse-local is pretty slick as well. You can operate directly on text files as if they were tables. I made my own toy text file database thing and thought I was cool because I could outrun similar programs like q, textql, sqlite, etc. But clickhouse-local had me by a factor of 10 easy in every kind of query with every type of data. Those guys know stuff.
We found the "lots of small inserts" issue, and fixed it by just using the Buffered table engine[0]. Can create it as a replica of the destination table, and it stores inserts in memory until they cross a threshold and are written. Super simple and took 5 minutes.
Very interesting observations! Merge performance tuning seems often overlooked even though it's a key aspect of sustained ClickHouse performance.
I also like that the blog is quite compact and gets the points across without getting too much into the weeds.
One thing I've noticed also that bloom filter index types can be quite costly to merge. In many cases that's acceptable though due to the massive benefit they provide for text queries. One just has to be mindful of the overhead when adding them.
Exploring bloom filter index merges would be an interesting addition. I do wish it were easier to profile merge performance to break down where most of the CPU time is being spent.
Thanks for sharing! I'm curious as to your approach to changing the ORDER BY key for such large tables without significant downtime, since AFAIK this can't be done in place (see: https://kb.altinity.com/altinity-kb-schema-design/change-ord...). Are you able to share any details?
Syntaf|1 year ago
I remember wanting to use Heap's session replay only to release they want hundreds of dollars per _month_, my last bill with highlight was $2.38 I recall.
That's all to say that I'm glad Highlight is figuring out how to scale while still offering their features to the small players of the world.
[1] https://embolt.app
tmzt|1 year ago
The pages clearly defined what you are building and how to use it.
The explanation of platform fees makes sense, though it could more clear if the pricing examples are only based on those fees or are account limits to number of members or dues.
You might want to check your terms of service, they do not list a jurisdiction and have the placeholder [jurisdiction] instead.
Best of luck with it!
podoman|1 year ago
jkercher|1 year ago
podoman|1 year ago
Dachande663|1 year ago
[0] https://clickhouse.com/docs/en/engines/table-engines/special...
dilyevsky|1 year ago
ericb|1 year ago
banditelol|1 year ago
Just a heads up, You've got repeated line there
YZF|1 year ago
podoman|1 year ago
ople|1 year ago
I also like that the blog is quite compact and gets the points across without getting too much into the weeds.
One thing I've noticed also that bloom filter index types can be quite costly to merge. In many cases that's acceptable though due to the massive benefit they provide for text queries. One just has to be mindful of the overhead when adding them.
vadman97|1 year ago
JosephRedfern|1 year ago
vadman97|1 year ago
* Create a new version of the table with the new ORDER BY.
* Create a materialized view that will insert from the old table to the new table.
* Update your application code to query the new table.
* Start inserting data into the new table.
misiek08|1 year ago
vadman97|1 year ago