MongoDB dump from 3.2, restore with 3.4, error index safe = null
Why do you restore indexes? --noIndexRestore and create them again.
In the spirit of Aymeric's comment, you can use this awk one-liner to replace the "safe" property in your .metadata.json files.
awk -i inplace '{gsub(",\"safe\":null", ""); print}' *.metadata.json
Run it in the directory of your MongoDB export. This approach allows you to keep the indexes, but drop the "safe" option.
safe=true
is not an index specification.
In previous versions of MongoDB, lower than 3.4, extra indexes specifications can be added. Those were used by specific drivers.
In 3.4, mongodb added a validation on indexes specification:
Ensuring that the specified index options are valid. Previous versions ignored invalid options.
That's why you have this error. I am afraid you need to ensure that the index in your 3.2 version does not have invalid index specificaitons, and after that do the mongodump.
As kz_sergey says in his answer, you can mongorestore
using --noIndexRestore
, that should work fine.