This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2017-09-06
Channels
- # beginners (147)
- # boot (12)
- # chestnut (12)
- # cider (22)
- # clara (10)
- # cljs-dev (6)
- # cljs-experience (3)
- # cljsrn (12)
- # clojure (58)
- # clojure-austin (3)
- # clojure-dusseldorf (25)
- # clojure-finland (20)
- # clojure-gamedev (1)
- # clojure-greece (3)
- # clojure-italy (32)
- # clojure-new-zealand (5)
- # clojure-russia (12)
- # clojure-serbia (1)
- # clojure-spec (4)
- # clojure-uk (51)
- # clojurescript (75)
- # cursive (8)
- # datomic (81)
- # fulcro (29)
- # graphql (16)
- # heroku (6)
- # incanter (1)
- # keechma (1)
- # lumo (44)
- # off-topic (21)
- # onyx (22)
- # parinfer (5)
- # portkey (40)
- # re-frame (43)
- # reagent (5)
- # spacemacs (37)
- # specter (8)
- # unrepl (3)
why run as www-data??
we have a common query that appears to be causing an out of memory on GC overhead. the query itself at the moment scans 3.3m records, which we then have to sort and page. Implementing a ranged query is top on my list, but are there any other recommendations?
@uwo have you done some optimization on the query itself? https://github.com/Datomic/day-of-datomic/blob/master/tutorial/decomposing_a_query.clj
@uwo so that sounds like a very scan-like operation - “find me all the entities” - I’d just use the datoms API
@marshall yeah, definitely I’ve considered that as well. Will the memory profile be identical though since I still have to sort before I take/drop?
initially, yes. though we’re populating a table, and the user can sort by up to 3 columns if they click on enough column headers
which means if you have additional sub-sorts, you’d only need to iterate through AVET until you reach a new V (i.e. the first ‘chunk’ of datoms that have the same value when sorted by your primary attribute), which you then would need to sub-sort by the additional attribute(s)
depending on your data size/distribution, that approach may be able to reduce your memory overhead
also, I realize this is app specific, but we’ve currently got 6GB on our app server. I’ve read the capacity planning documentation, but I’m still a little unsure how to figure out how large an object cache we should target,etc. any tips?
it entirely depends on what your app is doing and what your db usage patterns are the default is half the heap
if you have a 6gb box and you’re running into memory pressure, i’d probably use more for the heap unless you are running other things on the box
also, if you can use memcached that will help alleviate a lot - you can potentially leave object cache alone (or even reduce it) while adding memcached to give your application more headroom
is there a datomic equivalent of LIMIT or FETCH FIRST N ROWs? Im running a query that returns thousands of entities and i only want the first 500
that takes the same amount of time to excute, so i'm assuming it's just filtering after the query has found all the thousands of results
(time (d/q '[:find (take 500 ?e) :in $ ?txt :where [(fulltext $ ::s/ACCT_NME_TXT ?txt) [[?e]]]] db "test")) "Elapsed time: 14039.683358 msecs"
so, result order is undefined, and querys run in a map/reduce fashion, so it's eager--it doesn't terminate early
we're trying to compare apples to apples with oracle text search which lets you short circuit the query with a limit
datomic is searching 8 million records and return 10000 in 12 seconds, but oracle responds in 2 seconds because it's only return the first 500
Unfortunately there is no Limit clause
If you use datoms
, you can build a query that uses take
, but ofc at that point you’re not using the query planner
is there a way to stop the query and just keep the results so far? i know having the queries run in the peer is great because your'e not blocking the 'db' like in sql but i could imagine not wanting my web server to block a thread for a minute if the user finds a nasty query
I'd love to be proven wrong, but AFAIK you can either use Datalog or limit the results, but not both - it's a real limitation.
kind of makes me want to find out how quickly d/datoms + java.lang.String#contains can return 500 items
I’m having trouble finding this info online: is there a way to drop/delete a Datomic partition? I’m testing out some schema stuff in a dev environment with datomic running in a docker container, and I’m having trouble figuring out how to override a attribute spec which I’ve already foolishly inserted into and now want to add :db.unique/identity
to. <- alternatively telling me how to do that via other means would work.
this isn't helpful? http://docs.datomic.com/schema.html#Schema-Alteration
well, I’m getting an error trying to add the constraint
and I assumed it was because of > In order to add a unique constraint to an attribute, Datomic must already be maintaining an AVET index on the attribute, or the attribute must have never had any values asserted.
http://docs.datomic.com/schema.html#altering-avet-index <- under that section
@ddellacosta so you’ve tried this? 1) add :db/index 2) d/request-index 3) add :db/unique
@uwo sorry for the slow response. I get this when I try to add an index (or set it unique for that matter)
CompilerException java.util.concurrent.ExecutionException: java.lang.IllegalArgumentException: :db.error/invalid-install-attribute Error: {:db/error :db.error/incompatible-schema-install, :entity :my/id, :attribute :db/index, :was nil, :requested true}, compiling:(form-init2080569204125065060.clj:1:35)
the :was nil
bit confuses me in particular
wonder if I’ve got something else wrong with this schema item
@ddellacosta can you share the tx data you're submitting to add index to your attribute
one sec
1│ [
2│ {:db/id #db/id[:db.part/db]
3│ :db/ident :my/id
4│ :db/index true
5│ ;; :db/unique :db.unique/identity
6│ :db/valueType :db.type/uuid
7│ :db/cardinality :db.cardinality/one
8│ :db/doc "UUID for the thing"
9│ :db.install/_attribute :db.part/db}]
sorry for the slightly weird formatting
basically I had that previously without the index
or unique
, messed around and transacted on a few things, then realized I wanted that to be unique
based on my reading of the schema doc, it sounds like I’m simply not going to be able to add unique
to it at this point because I’ve already transacted some data
so I figured the best thing to do was delete the partition
this is all dev work so I don’t care about this data so much
0.9.5544
I believe is what you’re looking for
{:db/ident :person/name :db/cardinality :db.cardinality/many ;; explicit alter :db.alter/_attribute :db.part/db}
so let me make sure I understand: I want this?
[{:db/ident :my/id
:db/unique :db.unique/identity
:db.alter/_attribute :db.part/db}]
got it--but where were you going with that? I’m curious
Just that if you're using explicit syntax you need to use alter attribute, not install
or is that it, I should also be able to simply do
[{:db/id :my/id
:db/unique :db.unique/identity}]
?I see
gotcha. I’ll have to go read up on the distinction between explicit syntax and the alternative, as I don’t think I understand that
nor have I ever seen that :db.alter/_attribute
thing
ah, I see
@marshall, I’m going to go give this a shot. Thanks so much for your help! I learned a lot.
@ddellacosta ^ talks about the implicit install and alter stuff
gotcha
great